1. 程式人生 > >qt延時 QT中簡單的延時辦法

qt延時 QT中簡單的延時辦法

來自 http://www.qtgtk.com/qt延時-qt中簡單的延時辦法/

QEventLoop eventloop;

QTimer::singleShot(time, &eventloop, SLOT(quit()));
eventloop.exec();

其中time代表延時時長。若QEventLoop是跨平臺的,則該延時辦法可跨平臺實現。

void sleep(unsigned int msec)

{

QTime dieTime = QTime::currentTime().addMSecs(msec);

while( QTime::currentTime() < dieTime )

QCoreApplication::processEvents(QEventLoop::AllEvents, 100);

}

關於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的作用。

另一種方法,不過沒試過:

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

同時可以

void myThread::run(int time)
{
usleep(time);
QMessageBox::information(0, “test “, “ok,test is successful! “);
}

轉載自: http://hi.baidu.com/potyzhang/item/cdc5e1bb572bc275254b09bf