接上一讲三、2、2>4》,创建logger.h和helper_t.h里的gettime函数
- 即解决下图的报红
同时,接上一讲二、3、点击“确认”按钮后,进入MainFrame.h对应的下述界面,此讲下图进行实现
一、创建Logger.h:日志记录文件,用于在指定路径下创建日志文件,提供方法写入日志信息
1、在helper_t.h中创建gettime函数
注意,师傅的helper_t.h是SDK库里的,不是自己写的
2、创建Logger.h
1>创建单例模式
1》单例模式:保证一个类只有一个实例,并提供一个全局访问点
《1》“实例”通常指的是某个类的具体对象。当你创建一个类的对象时,这个对象就是一个“实例”。
- 实例是指某个类的具体对象,它是数据结构和方法的集合。
.NET6 WebApi第3讲:控制反转(IOC)和依赖注入(DI)、依赖倒置、服务(如何使用?三种生命周期)、typeof()、Autofac(增强IOC容器)_net6 ioc-CSDN博客
《2》为什么返回引用?——保证唯一性(单例的关键)
返回引用是为了确保单例唯一性、避免拷贝开销【见2》】
《3》代码
2》这个全局的唯一访问点在MainFrame.h中
《1》extern的用途:声明一个变量或函数(.h),并指示该变量或函数实际定义在另一个文件中(对应的.cpp)
《2》代码
在头文件(MainFrame.h)里声明(加上extern),源文件(MainFrame.cpp)中定义(这是全局的唯一访问点)
- 声明:头文件中的
extern
声明告诉其他源文件(包括实现文件本身)存在这样一个变量,但并不为其分配空间。- 你可以在多个文件中包含这个声明,而不会引起冲突。
- 定义:源文件中的定义则提供了具体的变量实现,分配了所需的内存,并完成了初始化。
- 每个变量只能有一个定义,否则会导致链接错误(重复定义)。
1)为什么要加 extern
?:让变量可以在多个其它源文件(.cpp)中被访问,但只在一个地方实际定义,避免重复定义错误
-
- 如果不加extern,那么
- 每个包含 MainFrame.h 的
.cpp
文件都会生成一个logger
变量的定义。 - 链接时就会报错:重复定义错误。
- 每个包含 MainFrame.h 的
2)为什么logger变量 要 使用引用?
因为1》中的GetInstance()函数返回值是Logger&引用。
- 返回引用是为了确保单例唯一性、避免拷贝开销
3》C++引用作为函数返回值
《1》基本语法
注意:只返回静态变量、外部变量或传递给函数的对象成员的引用
- 如果函数返回的是局部变量的引用,则该引用指向的内容会在函数退出时被销毁,因此会导致悬空引用的问题
《2》c++引用作为函数返回值的三个作用:
《3》const在*前后的不同意义:根据“靠近原则”,const
关键字更靠近哪一部分,就表示那一部分是常量
- 如果
const
位于*
的左边(如const int *ptr
或int const *ptr
),则表示指向的内容是常量(指向常量的指针)。- 这意味着你不能通过该指针修改所指向的数据,但你可以改变指针本身指向哪个地址。
- 如果
const
位于*
的右边(如int* const ptr
),则表示指针自身是常量(指针常量)。- 这表示指针本身的地址是固定的,即指针一旦初始化后,就不能再指向其他地址。但是,如果指针指向的对象不是常量的话,它的值仍然可以通过其他方式修改。
2>Logger构造函数:设置日期决定当天的日志写入哪个文件,检查并创建日志文件目录(文件名加上当天日期)
1》GetCurrentDate函数:获取当前时间
strftime(string format time):标准 C 库函数,用于将时间信息格式化为自定义的字符串表示形式
2》CreateDirectory函数:创建并检查目录
对于 Windows 平台,应该包含 <direct.h>
头文件来使用 _mkdir
函数。
而在 POSIX 系统(如 Linux 和 macOS)上,则应包含 <sys/stat.h>
和 <sys/types.h>
来使用 mkdir
函数。
3》Logger构造函数完整代码
3>Log函数
由于2、的Logger类是1>单例模式,所以Logger构造函数只会在代码运行后执行一次。所以日志记录主要功能都在这个Log函数中。
Log函数的功能:按照日期决定当天的日志写入哪个文件(要防止多个线程同时写入同一个文件,因为在代码多处需要日志记录的地方可能都会调用Log函数)
1》防止多个线程同时写入同一个文件
std::lock_guard<std::mutex> lock(mutex_);
这一行会在进入作用域时自动对mutex_
加锁,并且在离开作用域(即函数结束或出现异常退出时)自动解锁。