下载此文档

Qt多线程编程.doc


文档分类:IT计算机 | 页数:约21页 举报非法文档有奖
1/21
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/21 下载此文档
文档列表 文档介绍
Qt线程类
Qt 包含下面一些线程相关的类:
QThread 提供了开始一个新线程的方法
QThreadStorage 提供逐线程数据存储
QMutex 提供相互排斥的锁,或互斥量
QMutexLocker 是一个便利类,它可以自动对QMutex 加锁与解锁
QReadWriterLock 提供了一个可以同时读操作的锁
QReadLocker 与QWriteLocker 是便利类,它自动对QReadWriteLock 加锁与解锁
QSemaphore 提供了一个整型信号量,是互斥量的泛化
QWaitCondition 提供了一种方法,使得线程可以在被另外线程唤醒之前一直休眠。
Qt线程的创建
Qt线程中有一个公共的抽象类,所有的线程都是从这个QThread抽象类中派生的,要实现QThread中的纯虚函数run(),run()函数是通过start()函数来实现调用的。
1 class MyThread : public QThread {
2 public :
3 virtual void run();
4 };
5
6 void MyThread::run()
7 {
8 for ( int count = 0 ; count < 20 ; count ++ ) {
9 sleep( 1 );
10 qDebug( " Ping! " );
11 }
12 }
13
14 int main()
15 {
16 MyThread a;
17 MyThread b;
18
19 (); // 自动调用run(),否则即使该线程创建,也是一开始就挂起
20 ();
21 // 要等待线程a,b都退出
22 ();
23 ();
24 }
25
Qt线程同步

QMutex ( bool recursive = FALSE )
virtual ~QMutex ()
void lock () //试图锁定互斥量。如果另一个线程已经锁定这个互斥量,那么这次调用将阻塞 直到那个线程把它解锁。
void unlock ()
bool locked ()
bool tryLock () //如果另一个进程已经锁定了这个互斥量,这个函数返回假,而不是一直等到这个锁可用为止,比如,它不是阻塞的。
1 // Qt
2 QMutex mutex;
3 void someMethod()
4 {
5 mutex. lock ();
6 qDebug( " Hello " );
7 qDebug( " World " );
8 ();
9 }
10
11 // 用Java的术语,这段代码应该是:
12 void someMethod()
13 {
14 synchronized {
15 qDebug( " Hello " );
16 qDebug( " World " );
17 }
18 }
不过在Qt中我们可用通过另一个类来简化这种应用,()()的话就会造成死锁,别的线程永远也得不到接触该mutex锁住的共享资源的机会。尽管可以不使用lock()而使用tryLock(timeout)来避免因为死等而造成的死锁( tryLock(负值)==lock()),但是还是很有可能造成错误。
对于上述的情况MFC中用CSingleLock 或 MultiLock,Boost中用boost::mutex::scoped_lock来进行解决,而在Qt中用QMutexLocker来进行解决。下面是没有采用 QMutexLocker的例子和采用 QMutexLocker的方案。

Qt多线程编程 来自淘豆网m.daumloan.com转载请标明出处.

非法内容举报中心
文档信息
  • 页数21
  • 收藏数0 收藏
  • 顶次数0
  • 上传人mkjafow
  • 文件大小67 KB
  • 时间2021-02-09
最近更新