免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7799 | 回复: 19
打印 上一主题 下一主题

[C++] 如何设计一个比较好的日志系统类? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-11-30 07:33 |只看该作者 |倒序浏览
一个大型系统,用C++写的,现在需要写一个日志类,用于记录整个系统的运行状态,以便出现问题时跟踪原因,
考虑的方法是设计一个log类,然后将运行过程中进入的模块名和部分变量名都及时打印在一个按日期命名的log文件里,
但是因为
每个模块调用这个类时总是要实例化一些,然后开始写文件,这样就会有大量的类对象创建和销毁的开销,请问有什么方法来避免这个问题呢
谢谢

论坛徽章:
3
CU大牛徽章
日期:2013-03-13 15:15:08CU大牛徽章
日期:2013-03-13 15:26:06CU大牛徽章
日期:2013-03-13 15:26:47
2 [报告]
发表于 2012-11-30 08:40 |只看该作者
log类维护个消息队列吧,其它模块向它投递消息,日志顺序处理。

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
3 [报告]
发表于 2012-11-30 08:51 |只看该作者
用单实例模式

论坛徽章:
0
4 [报告]
发表于 2012-11-30 11:38 |只看该作者
2L 正解啊,开个单独的日志线程负责从队列里面取消息写入文件,这样你的日志的滚动功能,buffer控制,格式的转换等等,都可以在这个线程中处理。

论坛徽章:
6
技术图书徽章
日期:2013-11-13 11:11:27子鼠
日期:2014-02-20 17:54:13处女座
日期:2014-06-16 17:43:33午马
日期:2014-08-08 09:11:17未羊
日期:2014-08-10 11:57:072015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2012-11-30 13:16 |只看该作者
难道是回家作业?

论坛徽章:
0
6 [报告]
发表于 2012-11-30 15:37 |只看该作者
这个就是c++比较恶心的地方,不能直接引用,还得弄个类实例化,C没问题,可以封装个静态库直接调API,像C一样

论坛徽章:
0
7 [报告]
发表于 2012-11-30 16:26 |只看该作者
log4cxx)

论坛徽章:
0
8 [报告]
发表于 2012-11-30 16:33 |只看该作者
对象的创建和销毁开销对于log来说九牛一毛。

有些人喜欢对C++那微不足道的额外开销斤斤计较,却对自己笨拙的设计视而不见。

论坛徽章:
0
9 [报告]
发表于 2012-11-30 16:39 |只看该作者
俺曾经对虚函数的两次寻址耿耿于怀,于是试遍了所有能想到的方法,发现虚函数的方案性能不差,代码最少,使用最方便。

论坛徽章:
0
10 [报告]
发表于 2012-11-30 18:38 |只看该作者
i use pantheios
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP