免费注册 查看新帖 |

Chinaunix

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

太神气了。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-17 02:08 |只看该作者 |倒序浏览
一个多线程程序,写入到log文件里的调试信息乱序了。

                        snprintf(__d_msg_buf, 2 * 1024,                 \
                                 "%lu:%s:%s( ):%4d:%6lu:%6lu: " format, \
                                 (unsigned long)time(NULL),             \
                                 __FILE__, __FUNCTION__, __LINE__,      \
                                 (unsigned long)getpid( ),              \
                                 (unsigned long)pthread_self( ), ##a);
这是打印到缓冲区,随后写入文件的宏。
而且事后发现getpid,pthread_self()都是相同的。也就是没有别的线程写这个日志文件。

论坛徽章:
0
2 [报告]
发表于 2010-03-17 09:27 |只看该作者
这个神奇是建立在一定条件的基础上的,请确保你的条件是否正确

论坛徽章:
0
3 [报告]
发表于 2010-03-17 09:43 |只看该作者

论坛徽章:
0
4 [报告]
发表于 2010-03-17 10:06 |只看该作者
getpid和pthread_self()可能都没被修改,一直沿用一开始的

论坛徽章:
0
5 [报告]
发表于 2010-03-17 10:32 |只看该作者
往buffer里写肯定不会出问题,我关心楼主是如何将buffer写到文件的... 是一个log线程么?

论坛徽章:
0
6 [报告]
发表于 2010-03-17 12:57 |只看该作者
3楼的签名是不是每一更新,一天一话
关注中。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP