经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C++ » 查看文章
C++实现单例模式日志输出详解
来源:jb51  时间:2023/4/24 8:50:30  对本文有异议

一、单例模式简单介绍

1.1 基础介绍

单例模式只保证一个程序内只有一个实例存在,并提供全局访问点来访问该实例,其实就是单例模式的类对象只允许存在一个,它和多线程思想恰恰相反,为的是保证操作资源的安全。比如日志系统需要记载时间的,如果多线程会搞得很乱。

实现单例模式的关键是构造函数需要被设为私有,以防止外部代码创建多个实例。同时,需要提供一个静态方法来获取实例,这个方法会检查是否已经有一个实例存在,如果存在就返回这个实例,否则就创建一个新的实例并返回。

下面是一个简单的 C++ 单例模式示例代码:

  1. class Singleton {
  2. public:
  3. static Singleton* GetInstance() {
  4. if (instance_ == nullptr) {
  5. instance_ = new Singleton();
  6. }
  7. return instance_;
  8. }
  9. void DoSomething() {
  10. // ...
  11. }
  12. private:
  13. Singleton() {
  14. // ...
  15. }
  16. static Singleton* instance_;
  17. };
  18. Singleton* Singleton::instance_ = nullptr;

1.2 单例模式使用场景

1.配置管理器:在一个应用程序中,配置信息可能需要在多个地方被访问,而且这些配置信息通常是只读的。使用单例模式可以保证配置信息只被加载一次,同时提供一个全局访问点来访问配置信息。

2.日志记录器:在一个应用程序中,日志信息可能需要在多个地方被记录,而且记录器通常是只有一个的。使用单例模式可以保证只有一个日志记录器被创建,并且提供一个全局访问点来记录日志信息。

3.数据库连接池:在一个应用程序中,需要连接数据库的地方可能很多,而且数据库连接通常是有限的资源。使用单例模式可以实现数据库连接池,保证连接只被创建一次,并且提供一个全局访问点来获取连接。

4.计数器:在一个应用程序中,可能需要对某个事件或操作进行计数统计,而且这些计数器通常是只有一个的。使用单例模式可以保证计数器只被创建一次,并且提供一个全局访问点来进行计数。

5.缓存管理器:在一个应用程序中,需要对某些数据进行缓存,而且缓存数据的容量通常是有限的。使用单例模式可以实现缓存管理器,保证缓存只被创建一次,并且提供一个全局访问点来访问缓存数据。

二、单例模式实现日志记录(Singleton Logger)

  1. #include <iostream>
  2. #include <fstream>
  3. #include <string>
  4. #include <ctime>
  5. using namespace std;
  6. class Logger {
  7. private:
  8. static Logger* instance;
  9. ofstream logFile;
  10. Logger() {
  11. string filename = "log.txt";
  12. logFile.open(filename.c_str(), ios::out | ios::app);
  13. }
  14. public:
  15. static Logger* getInstance() {
  16. if (instance == NULL) {
  17. instance = new Logger();
  18. }
  19. return instance;
  20. }
  21. void log(string message) {
  22. time_t now = time(0);
  23. char* dt = ctime(&now);
  24. logFile << dt << ": " << message << endl;
  25. }
  26. };
  27. Logger* Logger::instance = NULL;
  28. int main() {
  29. Logger* logger = Logger::getInstance();
  30. logger->log("Hello World!");
  31. return 0;
  32. }

在上述代码中,Logger类具有私有的构造函数和一个私有的静态成员变量instance。getInstance()函数是一个公有的静态成员函数,它返回Logger类的唯一实例。如果实例不存在,则创建一个新的实例。log()函数用于向日志文件写入消息。

在main函数中,我们首先获取Logger实例,然后调用log()函数记录日志。由于Logger类是单例模式,因此在程序运行期间只会有一个Logger实例存在,因此多次调用log()函数将在同一个文件中记录日志。

请注意,由于单例模式在多线程环境下可能存在问题,因此需要进行线程安全的处理。在本例中,我们忽略了线程安全问题,仅提供了单线程环境下的实现。

三、总结

单例模式很辛苦,很孤单,请善待单例模式。

到此这篇关于C++实现单例模式日志输出详解的文章就介绍到这了,更多相关C++单例模式内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号