偶然从书中看到,感觉这是个隐藏的知识点,很容易误入其中,却不得原因,便记录于此,帮助后初学者放置入坑。
根据《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,这本书是非常适合参考的。