• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            在Qt中使用sleep

            https://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,但是waitsleep的作用是不同的。

            sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非

            (a)“醒來”的線程具有更高的優先級。

            (b)正在運行的線程因為其它原因而阻塞。

            wait()會使調用它的線程暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。

            3.        查看sleep的源代碼,使用Qtwin下和*nix下的sleep函數。

            Windows下的sleep的代碼為:

            void QThread::sleep(unsigned long secs)

            {

                ::Sleep(secs * 1000);

            }

            sleep的單位為秒。

            *nixsleep的代碼為:

            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

            來源:CSDN

            原文:https://blog.csdn.net/tingsking18/article/details/5304254?utm_source=copy

            版權聲明:本文為博主原創文章,轉載請附上博文鏈接!

            posted on 2018-10-09 17:33 zmj 閱讀(1984) 評論(0)  編輯 收藏 引用

            精品蜜臀久久久久99网站| 久久精品国产亚洲αv忘忧草| 久久精品无码专区免费青青| 久久久久亚洲AV无码永不| 国产精品一区二区久久精品无码| 久久se精品一区精品二区国产| 久久久久se色偷偷亚洲精品av| 久久91亚洲人成电影网站| 色综合久久久久综合99| 97久久久久人妻精品专区| 久久露脸国产精品| 久久精品无码一区二区三区| 久久久SS麻豆欧美国产日韩| 91久久精品国产91性色也| 人妻无码久久一区二区三区免费 | 亚洲国产另类久久久精品小说| 久久青青草原精品影院| 一本久久a久久精品vr综合| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 无码国内精品久久人妻蜜桃| 久久久久国产精品嫩草影院| 99精品久久精品一区二区| 亚洲AV无码久久精品蜜桃| 亚洲国产精品嫩草影院久久| 91麻精品国产91久久久久| 国产69精品久久久久777| 欧美噜噜久久久XXX| 蜜臀av性久久久久蜜臀aⅴ麻豆| 武侠古典久久婷婷狼人伊人| 久久精品国产精品亚洲人人 | 欧美精品一本久久男人的天堂| 久久只有这里有精品4| 久久国产影院| 天天做夜夜做久久做狠狠| 精品久久久久久无码免费| 嫩草影院久久99| 久久国产香蕉视频| 模特私拍国产精品久久| 久久人人爽人人爽人人片AV麻烦| 久久亚洲熟女cc98cm| 亚洲国产精品久久久天堂|