当前位置: 首页 > news >正文

网站开发培训机构哪个好哈尔滨最新

网站开发培训机构哪个好,哈尔滨最新,郑州app制作,做网站的素材图片文章目录 一、实现一个简单的日志1.简介2.可变参数3.错误等级4.时间5.打印每一条参数6.与前面的一些代码搭配使用 二、完整代码 一、实现一个简单的日志 1.简介 我们运行代码的时候,我们希望有各种各样的运行时候的一些信息。这也就是日志 它一半有日志时间&…

文章目录

  • 一、实现一个简单的日志
    • 1.简介
    • 2.可变参数
    • 3.错误等级
    • 4.时间
    • 5.打印每一条参数
    • 6.与前面的一些代码搭配使用
  • 二、完整代码

一、实现一个简单的日志

1.简介

我们运行代码的时候,我们希望有各种各样的运行时候的一些信息。这也就是日志

它一半有日志时间,日志的等级,日志的内容,文件的名称和行号。

对于日志等级一半有如下的

Info : 常规消息

Warning : 报警信息

Error : 比较严重了,可能需要立即处理

Fatal : 致命的

Debug : 调试

2.可变参数

关于可变参数我们主要用下面四个中的前三个

image-20240121184554880

我们用如下代码来简单的介绍一下

int sum(int n, ...)
{//char* 可以去提取一个一个的参数va_list s;va_start(s, n);int SUM = 0;for(int i = 0; i < n; i++){SUM += va_arg(s,int);}va_end(s); //s = NULLreturn SUM;
}

image-20240121191257243

在这段代码中,这个va_list其实就是一个char*类型的指针。

我们这个可变参数的函数至少需要带有一个参数。

因为我们传递参数的时候是从右向左传递的,所以我们是可以确定出栈顶的元素就是我们所确定的一个元素的地址

这个va_start是一个宏,代表着让s这个指针指向n。也就是栈顶

然后我们va_arg也是一个宏,它的作用是让s指针往栈里面移动第二个参数的类型大小,并解引用

va_end这个宏的作用是让指针置为空

最终我们就可以计算出这个sum的大小了。这个第一个参数我们一般是用作确定后面的参数有几个

image-20240121191705000

像我们所谓的printf里面也是类似的方法,不过要注意的时候,因为第一个参数是字符串参数,它是可以通过解析字符串里面的%s等格式化控制来确定后面有几个参数的,从而完成依次的替换的。

3.错误等级

我们现在来设计我们的日志的函数

只需要下面这样即可

void logmessage(int level, char* format, ...)
{}

首先对于等级,我们可以直接用宏来表示

#define Info 0
#define Debug 1
#define Warning 2
#define Error 3
#define Fatal 4

4.时间

接下是时间,我们可以使用时间戳,不过其实还有其他的系统调用接口

image-20240121193700415

#include <sys/time.h>
int gettimeofday(struct timeval *tv, struct timezone *tz);

第一个参数是一个结构体,里面的两个参数它可以获取秒,微秒。

第二个参数与时区相关,我们可以不用管,直接置为NULL即可

还有一个接口是这样的

#include <time.h>
struct tm *localtime(const time_t *timep);

image-20240121194806434

这个函数的功能是将时间戳转化为一个结构体,这个结构体里面有时分秒月年等信息

我们可以简单的应用一下

image-20240121200140083

我们会注意到时间存在一定的问题,这是因为它是从1900年开始计时的,这个月是从0开始的,所以我们可以进行一下调整

image-20240121200322663

如下所示就正确了

void logmessage(int level, char* format, ...)
{time_t t = time(nullptr);struct tm* ctime = localtime(&t);printf("%d-%d-%d %d:%d:%d\n",ctime->tm_year + 1900, ctime->tm_mon + 1, ctime->tm_mday, ctime->tm_hour, ctime->tm_min, ctime->tm_sec);
}

image-20240121200416569

5.打印每一条参数

我们可以用vsnprintf函数

image-20240121204556637

最终我们的代码为如下

void logmessage(int level, char* format, ...)
{char leftbuffer[SIZE];time_t t = time(nullptr);struct tm* ctime = localtime(&t);snprintf(leftbuffer, SIZE,"[%s][%d-%d-%d %d:%d:%d]", levelToString(level).c_str(), ctime->tm_year + 1900, ctime->tm_mon + 1, ctime->tm_mday, ctime->tm_hour, ctime->tm_min, ctime->tm_sec);char rightbuffer[SIZE];va_list s;va_start(s, format);vsnprintf(rightbuffer, SIZE, format, s);va_end(s);char logtxt[2*SIZE];snprintf(logtxt, sizeof(logtxt), "%s %s\n", leftbuffer, rightbuffer);std::cout << logtxt << std::endl;
}  

image-20240121210712783

6.与前面的一些代码搭配使用

如下所示,这里我们就引进了我们刚刚使用的日志

image-20240121211321574

运行结果如下,我们现在可以看到,这样子就规范多了

image-20240121211442163

二、完整代码

如下代码所示,我们再将前面的日志给封装成一个类,然后实现一下分类打印,向文件打印,向显示屏打印等等功能。

#pragma once#include <stdarg.h>
#include <iostream>
#include <time.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>#define SIZE 1024#define Info 0
#define Debug 1
#define Warning 2
#define Error 3
#define Fatal 4#define Screen    1
#define Onefile   2
#define Classfile 3#define LogFile "log.txt"class Log
{
public:Log(){printMethod = Screen;path = "./log/";}void Enable(int method){printMethod = method;}std::string levelToString(int level){switch(level){case Info : return "Info";case Debug : return "Debug";case Warning : return "Warning";case Error : return "Error";case Fatal : return "Fatal";default : return "None";}}void operator()(int level, char* format, ...){char leftbuffer[SIZE];time_t t = time(nullptr);struct tm* ctime = localtime(&t);snprintf(leftbuffer, SIZE,"[%s][%d-%d-%d %d:%d:%d]", levelToString(level).c_str(), ctime->tm_year + 1900, ctime->tm_mon + 1, ctime->tm_mday, ctime->tm_hour, ctime->tm_min, ctime->tm_sec);char rightbuffer[SIZE];va_list s;va_start(s, format);vsnprintf(rightbuffer, SIZE, format, s);va_end(s);char logtxt[2*SIZE];snprintf(logtxt, sizeof(logtxt), "%s %s\n", leftbuffer, rightbuffer);//std::cout << logtxt << std::endl;PrintLog(level, logtxt);}   // void logmessage(int level, char* format, ...)// {//     char leftbuffer[SIZE];//     time_t t = time(nullptr);//     struct tm* ctime = localtime(&t);//     snprintf(leftbuffer, SIZE,//         "[%s][%d-%d-%d %d:%d:%d]", levelToString(level).c_str(), //         ctime->tm_year + 1900, ctime->tm_mon + 1, ctime->tm_mday, ctime->tm_hour, ctime->tm_min, ctime->tm_sec);//     char rightbuffer[SIZE];//     va_list s;//     va_start(s, format);//     vsnprintf(rightbuffer, SIZE, format, s);//     va_end(s);//     char logtxt[2*SIZE];//     snprintf(logtxt, sizeof(logtxt), "%s %s\n", leftbuffer, rightbuffer);//     //std::cout << logtxt << std::endl;//     PrintLog(level, logtxt);// }   void PrintLog(int level, const std::string& logtxt){switch(printMethod){case Screen:std::cout << logtxt << std::endl;break;case Onefile:PrintOnefile(LogFile , logtxt);break;case Classfile:PrintClassfile(level, logtxt);break;default: break;}}void PrintOnefile(const std::string& filename, const std::string& logtxt){std::string logname = path + filename;int fd = open(logname.c_str(), O_WRONLY|O_CREAT|O_APPEND, 0666);if(fd < 0){return;}write(fd, logtxt.c_str(), logtxt.size());close(fd);}void PrintClassfile(int level, const std::string& logtxt){std::string filename = LogFile;filename += ".";filename += levelToString(level);PrintOnefile(filename, logtxt);}~Log(){}
private:int printMethod;std::string path;
};
http://www.15wanjia.com/news/9404.html

相关文章:

  • 做名片哪个网站最好百度推广步骤
  • 秦皇岛市住建委网站上海百度推广开户
  • 真人百家樂网站建设企业宣传方式有哪些
  • 自己做的网站根目录哪里找到sem推广托管公司
  • 校园网站设计与实现南宁百度seo优化
  • 怎么做网站排版搜索引擎优化是指
  • 网站空间在哪里长春网站提升排名
  • 那个网站可以做视频app制作的360推广联盟
  • 做静态网站需要成本吗nba最新排行榜
  • 视频网站建设需要多少钱百度收录权重
  • 商务网站创建经费预算搜索引擎的工作原理是什么
  • 网站制作体会营业推广策略有哪些
  • 个人网站的设计与制作论文本地广告推广平台哪个好
  • 云主机建立web网站广告推广怎么做
  • 洛阳网站建设招聘信息免费个人网站空间
  • 重庆医疗网站建设2023很有可能再次封城吗
  • 网站备案照片新冠疫情最新情况最新消息
  • 电子商务网站建设的知识点新媒体营销策略
  • 安顺网站开发网站建设设计
  • pc端与手机端网站开发的区别网站快速优化排名app
  • 新能源电动汽车价格表阿里巴巴怎么优化关键词排名
  • 做ui设计用什么素材网站知乎小说推广对接平台
  • 如何设计产品网站建设企业网站建设论文
  • 深圳网站关键词百度搜索推广
  • 做ic贸易去什么网站好google app
  • 上海做网站的公司名称郑州最新通告
  • 网站 系统设置抖音广告投放平台官网
  • 大庆网站优化买了500元黑科技引流靠谱吗
  • 甘谷县建设局网站百度投诉中心电话24个小时
  • 深圳网站建设怎样做福州网络营销推广公司