關(guān)于sleep函數(shù),我們先來看一下他的作用:sleep函數(shù)是使調(diào)用sleep函數(shù)的線程休眠,線程主動放棄時間片。當(dāng)經(jīng)過指定的時間間隔后,再啟動線程,繼續(xù)執(zhí)行代碼。sleep函數(shù)并不能起到定時的作用,主要作用是延時。在一些多線程中可能會看到sleep(0);其主要目的是讓出時間片。sleep函數(shù)的精度非常低,當(dāng)系統(tǒng)越繁忙的時候它精度也就越低,有時候我們休眠1秒,可能3秒后才能繼續(xù)執(zhí)行。它的精度取決于線程自身優(yōu)先級、其他線程的優(yōu)先級,以及線程的數(shù)量等因素,所以說sleep函數(shù)是不能用來精確計時的。
Qt為我們提供了幾個可以用于線程Sleep的函數(shù),分別是:
void QThread::sleep ( unsigned long secs ) [static protected]
void QThread::msleep ( unsigned long msecs ) [static protected]
void QThread::usleep ( unsigned long usecs ) [static protected]
sleep的單位分別是秒、毫秒、微秒。
但是現(xiàn)在問題出來了,請仔細(xì)看上面的函數(shù)定義,函數(shù)的訪問權(quán)限都是protected,這就意味著,我們必須在QThread或者他的繼承類中使用這三個函數(shù)。
但是我們可能需要在非繼承QThread的類中來使用sleep函數(shù)。那這該這么辦呢?下面我就給大家提供幾種解決方法。
1. processEvents
QTime dieTime = QTime::currentTime().addMSecs(svalue);
while( QTime::currentTime() < dieTime )
QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
調(diào)用processEvents會讓Qt繼續(xù)處理線程所在的消息隊列中未處理的消息,直到消息隊列中沒有消息可以處理。當(dāng)進(jìn)行長時間的操作的時候可以調(diào)用此函數(shù)(比方說拷貝文件)。這個函數(shù)可能和我們要使用msleep的本意有差別,但是使用它可以在svalue時間內(nèi)處理events,從而達(dá)到類似sleep的目的。
2. QWaitCondition
QWaitCondition wait;
wait.wait(time);
wait的單位是milliseconds,但是wait和sleep的作用是不同的。
sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立即恢復(fù)執(zhí)行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調(diào)度為放棄執(zhí)行,除非
(a)“醒來”的線程具有更高的優(yōu)先級。
(b)正在運行的線程因為其它原因而阻塞。
wait()會使調(diào)用它的線程暫停執(zhí)行,被調(diào)對象進(jìn)入等待狀態(tài),直到被喚醒或等待時間到。
3. 查看sleep的源代碼,使用Qt在win下和*nix下的sleep函數(shù)。
Windows下的sleep的代碼為:
void QThread::sleep(unsigned long secs)
{
::Sleep(secs * 1000);
}
sleep的單位為秒。
*nix下sleep的代碼為:
void QThread::sleep(unsigned long secs)
{
struct timeval tv;
gettimeofday(&tv, 0);
struct timespec ti;
ti.tv_sec = tv.tv_sec + secs;
ti.tv_nsec = (tv.tv_usec * 1000);
thread_sleep(&ti);
}
static void thread_sleep(struct timespec *ti)
{
pthread_mutex_t mtx;
pthread_cond_t cnd;
pthread_mutex_init(&mtx, 0);
pthread_cond_init(&cnd, 0);
pthread_mutex_lock(&mtx);
(void) pthread_cond_timedwait(&cnd, &mtx, ti);
pthread_mutex_unlock(&mtx);
pthread_cond_destroy(&cnd);
pthread_mutex_destroy(&mtx);
}
我們可以對這兩個函數(shù)進(jìn)行簡單的封裝,從而達(dá)到真正的sleep的作用。
---------------------
作者:tingsking18
來源:CSDN
原文:https://blog.csdn.net/tingsking18/article/details/5304254?utm_source=copy
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請附上博文鏈接!