Qt 延時


第一部分:

關於sleep函數,我們先來看一下他的作用:sleep函數是使調用sleep函數的線程休眠,線程主動放棄時間片。當經過指定的時間間隔后,再啟動線程,繼續執行代碼。sleep函數並不能起到定時的作用,主要作用是延時。在一些多線程中可能會看到sleep(0);其主要目的是讓出時間片。sleep函數的精度非常低,當系統越繁忙的時候它精度也就越低,有時候我們休眠1秒,可能3秒后才能繼續執行。它的精度取決於線程自身優先級、其他線程的優先級,以及線程的數量等因素,所以說sleep函數是不能用來精確計時的。 Qt為我們提供了幾個可以用於線程Sleep的函數,分別是: 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的單位分別是秒、毫秒、微秒。 但是現在問題出來了,請仔細看上面的函數定義,函數的訪問權限都是protected,這就意味着,我們必須在QThread或者他的繼承類中使用這三個函數。 但是我們可能需要在非繼承QThread的類中來使用sleep函數。那這該這么辦呢?下面我就給大家提供幾種解決方法。 1.    processEvents     QTime dieTime = QTime::currentTime().addMSecs(svalue);     while( QTime::currentTime() < dieTime )     QCoreApplication::processEvents(QEventLoop::AllEvents, 100); 調用processEvents會讓Qt繼續處理線程所在的消息隊列中未處理的消息,直到消息隊列中沒有消息可以處理。當進行長時間的操作的時候可以調用此函數(比方說拷貝文件)。這個函數可能和我們要使用msleep的本意有差別,但是使用它可以在svalue時間內處理events,從而達到類似sleep的目的。 2.        QWaitCondition        QWaitCondition wait;        wait.wait(time); wait的單位是milliseconds,但是wait和sleep的作用是不同的。 sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非 (a)“醒來”的線程具有更高的優先級。 (b)正在運行的線程因為其它原因而阻塞。 wait()會使調用它的線程暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。 3.        查看sleep的源代碼,使用Qt在win下和*nix下的sleep函數。 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); } 我們可以對這兩個函數進行簡單的封裝,從而達到真正的sleep的作用。 版權聲明
本文為原創作品,請尊重作者的勞動成果。轉載必須保持文章完整性,並以超鏈接形式注明原始作者“tingsking18”和主站點地址,方便其他朋友提問和指正。http://jinsuo2007.blog.163.com/blog/static/192279952011875724406/



Qt4——程序延時的方法 http://blog.csdn.net/sunnyskyliu/article/details/6721277
1: void QTimer::singleShot ( int msec, QObject * receiver, const char* member ) [static] 
樣例: #include<QApplication> #include<QTimer> int main(int argc, char *argv[]) {   QApplication app(argc, argv);   QTimer::singleShot(600000,&app, SLOT(quit()));   ...   return app.exec(); }
2:以毫秒計
    QTimen=QTime::currentTime();     QTimenow;     do{          qDebug()<<"jjmm";         now=QTime::currentTime();     }   while(n.msecsTo(now)<=1);

3:以秒計
QDateTime n2=QDateTime::currentDateTime();   QDateTime now;   do{   now=QDateTime::currentDateTime();   } while(n2.secsTo(now)<=6);//6為需要延時的秒數

 

 

 

 

第二部分:

QT_讓程序休息一會 sleep
2011-09-22 15:48

在qt中不能直接使用sleep()函數,經查看可以發現,sleep在QThread中定義的有,但他是private模式,外部函數無法調用。利用一下方法可以實現sleep效果。我用的是第一種方法。

方法一:

class SleeperThread : public QThread { public:     static void msleep(unsigned long msecs)     {         QThread::msleep(msecs);     } };

// 調用方法 SleeperThread::msleep(1000);

方法二:

QMutex mutex; QWaitCondition sleep; mutex.lock(); sleep.wait(&mutex, 1000); mutex.unlock();

來自: http://hi.baidu.com/%CE%D2%B6%A5%D0%ED%CE%A1/blog/item/bc0e5fd9d62af0c28c1029c3.html
 
 
 
第三部分:
sleep()//秒 msleep()//毫秒 usleep()//微秒 以前為了模擬鼠標點擊用過這些函數,可以讓進程中斷,今天發現我原來的做法其實不對. 這組函數會將你當前的線程/進程變為“睡眠”狀態。 這個“睡眠”是深度意義的睡眠, 睡眠期間內核不會分配給程序時間片, 所以程序什么都不做, 更不用提界面的刷新了。 直接導致的問題就是用戶無法與程序交互。 所以說直接使用sleep函數睡眠是常見的錯誤方案之一。 另外一種更常見的錯誤方法是使用QTimer+死循環。 類似下面的代碼: QTimer t; t.start(); while(t.elapsed() < 250);
這個簡單粗暴的解決方案也是行不通的。 從代碼中我們可以發現在while循環中不停的調用elapsed()函數, 等於在這段時間內CPU完全沒有機會做別的什么事情。 特別是在Linux這樣非搶占式的操作系統中, 這樣的死循環造成的影響是致命的, CPU被完全占用, 內核都沒有機會調度進程, 別的程序拿不到時間片執行, 系統基本上就是癱瘓狀態了。 無論如何, 這種結果都不是我們想要的。(當然拉, 除非你想寫的是病毒程序。) 對於我們的程序本身, 雖然它占用了所有的CPU, 但由於它陷入該循環, 程序沒有機會進入到GUI事件循環, 導致同樣界面是無法刷新的。
其實把上面的代碼稍加改變就能得到一個很好的解決方案。 第一步, 解決界面無法刷新的問題。 調用QCoreApplication::processEvents(), 代碼如下: QTimer t; t.start(); while(t.elapsed() < 250) { QCoreApplication::processEvents(); }
第二步, 解決程序CPU占用率過高的問題 -- 讓程序適當睡眠。 QTimer t; t.start(); while(t.elapsed() < 250) { QCoreApplication::processEvents(); usleep(10000);//sleep和usleep都已經obsolete,Linux下也可以使用nanosleep代替 }
以后要用,就可以直接用上面的代碼了,用usleep()就可以了,那個nanosleep()則是Linux中的系統調用,它是使用定時器來實現的,該調用使調用進程睡眠,並往定時器隊列上加入一個timer_list型定時器,time_list結構里包括喚醒時間以及喚醒后執行的函數,通過nanosleep()加入的定時器的執行函數僅僅完成喚醒當前進程的功能。系統通過一定的機制定時檢查這些隊列(比如通過系統調用陷入核心后,從核心返回用戶態前,要檢查當前進程的時間片是否已經耗盡,如果是則調用 schedule()函數重新調度,該函數中就會檢查定時器隊列,另外慢中斷返回前也會做此檢查),如果定時時間已超過,則執行定時器指定的函數喚醒調用進程。當然,由於系統時間片可能丟失,所以nanosleep()精度也不是很高。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM