std::cout和printf

   禁止std::cout和printf混用,在多线程环境下可能导致coredump。

说明:printf和std::cout分别为标准c语言与c++中的函数,两者的缓冲区机制不同(printf无缓冲区,而std::cout有),而且对于标准输出的加锁时机也略不同:

(1)printf:在对标准输出作任何处理前先加锁。

(2)std::cout:在实际向标准输出打印时方才加锁。

    两者存在微弱的时序差别,而多线程环境下,很多问题就是由于微弱的时序差别造成的。所以两者的混用很容易带来不可预知的错误,常见的错误有打印输出的结果不符合预期,而严重错误时甚至会导致内部缓冲区溢出,导致coredump。

例如:

    void Nocomplaint()

{

  int j=0;

  for(j=0;j<5;j++)

 {

   cout << "j=";

   printf("%d\n",j);

 }

}

上面代码的输出结果可能为:1 2 3 4 j=j=j=j=j=

   造成这样的错误的原因就是std::cout的标准流输出时带有缓冲区的,如果没有及时清理缓冲区而在期间采用了其他系统的输出函数。可能会暴露两种输出函数的不兼容性,从而出现非预期错误。

原文链接: https://www.cnblogs.com/wangfengju/p/6173022.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

    std::cout和printf

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/93589

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月10日 上午2:13
下一篇 2023年2月10日 上午2:14

相关推荐