QT延時方法

(轉自:http://blog.sina.com.cn/s/blog_613cfe940100kacm.html

1、

void sleep(unsigned int msec)
{
    QTime dieTime = QTime::currentTime().addMSecs(msec);
    while( QTime::currentTime() < dieTime )
        QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
}

 

2、

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();
 }

3、以毫秒計

    QTime n=QTime::currentTime();
    QTime now;
    do{
         qDebug()<<"jjmm";
        now=QTime::currentTime();
    }   while(n.msecsTo(now)<=1);


4、以秒計

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

5、tingsking18(http://blog.csdn.net/tingsking18/article/details/5304254)

關於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的單位爲秒。

 

linix下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的作用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章