标签:处理 log 不可 输出 线程 问题 std 时机 缓冲区溢出
1、两者的缓存机制不同:printf无缓冲区,而std::cout有 (其实printf也是有缓冲区的,https://blog.csdn.net/ithzhang/article/details/6875176)
2、对于标准输出的加锁时机不同:printf在对标准输出作任何处理前先加锁;std::out在实际向标准输出打印时才加锁
3、二者存在微弱的时序差别,而在多线程环境下,很多问题就是由于微弱的时序差别造成的。所以两者混用很容易带来不可预知的错误,常见的错误有打印输出的结果不符合预期,而严重错误时甚至会导致内部缓冲区溢出,导致crash。
标签:处理 log 不可 输出 线程 问题 std 时机 缓冲区溢出
原文地址:https://www.cnblogs.com/shihuvini/p/9974921.html