我们编写一个Log类,通常是管理我们日志的一种方式,在之前笔记中我常常用其将文字打印在调试台上,这对我们调试代码有很大帮助,知道运行在哪里、什么东西没有运行。在今后的笔记中,我们可以看到Log类逐渐完善。Log类不单单打印到调试台,我们还可以做到用不同颜色打印、打印消息到某某文件中等等。
我们从最简单的Log类开始,我们运行经常出现的info、error、waring等级提示就是日志的一种,所以我们来创建一下。
class Log
{
};
int main()
{
Log log;
std::cin.get();
}
1.创建class类名为Log,注意{};类创建要有分号。
2.我们需要Log类做什么事情(创建什么方法)这就要看我们的需求。我们要做到的是将情况分为三类跟踪信息、错误、警告三类等级,以及在各个等级后标明具体问题,参考我们程序报错时打印的东西。
3.根据需求我们编写了以上两个函数,一个是设计等级,另一个是打印信息,我们将其放在class中。
class Log
{
private:
int m_LogLevel;
public:
void SetLevel(int level)
{
m_LogLeve = level;
}
void Warn(const char* message)
{
}
};
int main()
{
Log log;
log.SetLevel(LogLevelWarning);
log.Warn("hello,it is warning");
std::cin.get();
}
4.设计等级函数,输入level赋值给成员变量m_LogLevel。目的是在warn函数内if语句判断不同的m_LogLevel值打印不同信息。
我们注意到m_LogLevel这个变量初始化处用了private,说明其只可以在类的内部函数调用,还有一件事我完全可以使用LogLevel进行命名 ,使用m_LogLevel前缀m_完全是为了自己可以根据变量名称直接看出是成员变量,还是如level一样的局部变量,个人习惯。
再说到level,我们定义的是一个int四字字节整数,我们虽然可以用0 1 2分别代表级别,但是大大降低了代码的可读性,所以我们需要对等级用宏。
class Log
{
public:
const int LogLevelError = 0;
const int LogLevelWarning = 1;
const int LogLevelInfo = 2;
private:
int m_LogLevel = LogLevelInfo;
public:
void SetLevel(int level)
{
m_LogLeve = level;
}
void Warn(const char* message)
{
}
};
int main()
{
Log log;
log.SetLevel(LogLevelWarning);
log.Warn("hello,it is warning");
std::cin.get();
}
5.我们再次建立公有成员分别代替0 1 2表示error warning information。并且我们对m_LogLevel赋值information使其默认就打印所有信息。至此我们完成了类中一个方法的建立。
class Log
{
public:
const int LogLevelError = 0;
const int LogLevelWarning = 1;
const int LogLevelInfo = 2;
private:
int m_LogLevel = LogLevelInfo;
public:
void SetLevel(int level)
{
m_LogLeve = level;
}
void Error(const char* message)
{
std::cout<<"[ERROR]"<<message<<std::endl;
}
void Warn(const char* message)
{
std::cout<<"[WARNING]"<<message<<std::endl;
}
void Info(const char* message)
{
std::cout<<"[INFORMATION]"<<message<<std::endl;
}
};
int main()
{
Log log;
log.SetLevel(LogLevelWarning);
log.Warn("hello,it is warning");
std::cin.get();
}
6.我们需要三个函数分别打印不同的效果,然而仅仅只是以上的函数不足以在不同级别时打印出不同函数。我们还需要加上条件语句,只有当相应等级时才可以使用相应的打印函数。
class Log
{
public:
const int LogLevelError = 0;
const int LogLevelWarning = 1;
const int LogLevelInfo = 2;
private:
int m_LogLevel = LogLevelInfo;
public:
void SetLevel(int level)
{
m_LogLeve = level;
}
void Error(const char* message)
{
if(m_LogLeve=LogLevelError)
std::cout<<"[ERROR]"<<message<<std::endl;
}
void Warn(const char* message)
{
if(m_LogLeve=LogLevelWarning)
std::cout<<"[WARNING]"<<message<<std::endl;
}
void Info(const char* message)
{
if(m_LogLeve=LogLevelInfo)
std::cout<<"[INFORMATION]"<<message<<std::endl;
}
};
int main()
{
Log log;
log.SetLevel(LogLevelWarning);
log.Warn("hello,it is warning");
std::cin.get();
}
运行后会发现系统报错,原因是LogLevelWarning未定义,又因为我们知道其已经在class内部被定义过,所以我们改成log.LogLevelWarning即可。
class Log
{
public:
const int LogLevelError = 0;
const int LogLevelWarning = 1;
const int LogLevelInfo = 2;
private:
int m_LogLevel = LogLevelInfo;
public:
void SetLevel(int level)
{
m_LogLeve = level;
}
void Error(const char* message)
{
if(m_LogLeve=LogLevelError)
std::cout<<"[ERROR]"<<message<<std::endl;
}
void Warn(const char* message)
{
if(m_LogLeve=LogLevelWarning)
std::cout<<"[WARNING]"<<message<<std::endl;
}
void Info(const char* message)
{
if(m_LogLeve=LogLevelInfo)
std::cout<<"[INFORMATION]"<<message<<std::endl;
}
};
int main()
{
Log log;
log.SetLevel(log.LogLevelWarning);
log.Warn("hello,it is warning");
std::cin.get();
}
以上就是根据需求建立一个非常基本的类的流程,虽然这个代码看起来非常简单有逻辑,但是却是十分糟糕的代码。
在接下来的笔记中我们会用不同概念代替这次建立的Log类,你就会看到为什么这个代码是糟糕的,在接下来的笔记中我们将学习如何改善代码,达到专业水平。
多多关注吧!!!!!!!!!!!!!!!!!!