• <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 閱讀(1961) 評論(0)  編輯 收藏 引用

            久久996热精品xxxx| 久久久久亚洲AV无码麻豆| 精品国产乱码久久久久久浪潮| 久久99精品久久久久久秒播| 久久se精品一区精品二区国产| 香港aa三级久久三级老师2021国产三级精品三级在 | 国产精品伦理久久久久久| 国内精品免费久久影院| 777午夜精品久久av蜜臀| 亚洲国产精品久久久久婷婷老年| 青青热久久国产久精品 | 久久国产精品成人片免费| 国产精久久一区二区三区| 久久午夜福利无码1000合集| 97精品伊人久久大香线蕉app| 亚洲精品高清一二区久久| 日本免费久久久久久久网站| 99精品国产综合久久久久五月天| 国产高清美女一级a毛片久久w| 熟妇人妻久久中文字幕| 亚洲国产成人久久精品99| 久久久精品免费国产四虎| 久久天天躁狠狠躁夜夜躁2O2O| 久久综合狠狠综合久久97色| 无码伊人66久久大杳蕉网站谷歌| 青青草国产97免久久费观看| 99久久www免费人成精品| 国产成人精品久久一区二区三区| 精品国产青草久久久久福利| 日韩精品久久久久久久电影| 午夜福利91久久福利| 国产三级精品久久| 99久久精品国产一区二区| 国产精品美女久久久m| 国产精品国色综合久久| 久久99亚洲网美利坚合众国| 国产成年无码久久久久毛片| 精品国产91久久久久久久| 久久久久久综合一区中文字幕| 久久91精品国产91久久户| 人妻无码αv中文字幕久久|