【Qt】多线程程序请勿使用printf()函数打印输出

偶然从书中看到,感觉这是个隐藏的知识点,很容易误入其中,却不得原因,便记录于此,帮助后初学者放置入坑。

根据《Qt5开发及实例》(电子工业出版社,ISBN:978-7-121-36157-9)书中第299页,讲到:

线程将因为调用printf() 函数而持有一个控制 I/O 的锁(lock),多个线程同时调用 printf() 函数在某些情况下将造成控制台输出阻塞,而使用 Qt 提供的 qDebug() 函数作为控制台输出则不会出现上述问题。

意思就是 每个线程如果都使用 printf() 函数的化,其实整个程序的各个线程都在 使用同一个 I/O 进程,所以会造成资源抢占和进程互斥。而使用 qDebug() 则不会。

将 printf(yourVar) 函数 替换为 qDebug()<< yourVar ,还要记得把头文件引用加上:include <QtDebug>

QString hello = "hello world";
printf("%s", hello);

改为: 

#include <QtDebug>

QString hello = "hello world";

qDebug()<<hello;

另外:

《Qt5开发及实例》(电子工业出版社,ISBN:978-7-121-36157-9)书很不错,适合当手册翻,如果你要使用Qt,这本书是非常适合参考的。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qilei2010

送我一张彩票中了平分

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值