青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

關于短延遲 sleep usleep nanosleep select

Posted on 2008-08-21 19:19 Prayer 閱讀(17041) 評論(1)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX
udelay(unsigned long usecs);
mdelay(unsigned long msecs);

前者用軟件循環指定的微妙數,后者調用前者達到延遲毫秒級。udelay 函數只能用于獲取較短的時間延遲,因為loops_per_second值的精度只有8位,所以,當計算更長的延遲時會積累出相當大的誤差。盡管最大能允許的延遲將近1秒(因為更長的延遲就要溢出),推薦的 udelay 函數的參數的最大值是取1000微秒(1毫秒)。延遲大于 11 毫秒時可以使用函數 mdelay。
要特別注意的是 udelay 是個忙等待函數(所以 mdelay 也是),在延遲的時間段內無法運行其他的任務,因此要十分小心,尤其是 mdelay,除非別無他法,要盡量避免使用。
mdelay 在 Linux 2.0 中并不存在,頭文件 sysdep.h 彌補了這一缺陷。

關于
usleep sleep 主要的差距在精確程度上,不過網友有關于這個方面的精辟論斷:
同樣我覺得
select也是比較好的定時機制,不過大家可以看igmp-proxy的源代碼。主函數里面用setitimer和select同時定時是一個相當好的想法。

#################################################################
再論精確延時(usleep,nanosleep,select)

/*
        make: gcc -o test_sleep test_sleep.c
*/
/*        #include "comm_main.h" */
#include <stdio.h>;
#include <stdlib.h>;
#include <time.h>;
#include <sys/time.h>;
#include <errno.h>;
#include <string.h>;
#include <unistd.h>;
#include <sys/types.h>;

#define PRINT_USEAGE { \
   fprintf(stderr,"\n Usage: %s usec ",argv[0]); \
   fprintf(stderr,"\n\n");\
}

int
main (int argc, char **argv)
{
unsigned int nTimeTestSec = 0;        /* sec */
unsigned int nTimeTest = 0;        /* usec */
struct timeval tvBegin;
struct timeval tvNow;
int ret = 0;
unsigned int nDelay = 0;        /* usec */
fd_set rfds;
struct timeval tv;
int fd = 1;
int i = 0;
struct timespec req;
unsigned int delay[20] =
    { 500000, 100000, 50000, 10000, 1000, 900, 500, 100, 10, 1, 0 };
int nReduce = 0;                /* 誤差 */

#if 0
if (argc < 2)
    {
      PRINT_USEAGE;
      exit (1);
    }
nDelay = atoi (argv[1]);
#endif

fprintf (stderr, "%18s%12s%12s%12s\n", "function", "time(usec)", "realTime",
           "reduce");
fprintf (stderr,
           "-------------------------------------------------------------------\n");

for (i = 0; i < 20; i++)
    {
      if (delay[i] <= 0)
        break;
      nDelay = delay[i];

      /*      test usleep */
      gettimeofday (&tvBegin, NULL);
      ret = usleep (nDelay);
      if (-1 == ret)
        {
          fprintf (stderr, " usleep error . errno=%d [%s]\n", errno,
                   strerror (errno));
        }
      gettimeofday (&tvNow, NULL);
      nTimeTest =
        (tvNow.tv_sec - tvBegin.tv_sec) * 1000000 + tvNow.tv_usec -
        tvBegin.tv_usec;
      nReduce = nTimeTest - nDelay;
      fprintf (stderr, "\t usleep       %8u   %8u   %8d\n", nDelay, nTimeTest,nReduce);


      /*      test nanosleep */
      gettimeofday (&tvBegin, NULL);
      req.tv_sec = nDelay / 1000000;
      req.tv_nsec = (nDelay % 1000000) * 1000;
      ret = nanosleep (&req, NULL);
      if (-1 == ret)
        {
          fprintf (stderr, "\t nanosleep    %8u   not support\n", nDelay);
        }
      else
        {
          gettimeofday (&tvNow, NULL);
          nTimeTest =
            (tvNow.tv_sec - tvBegin.tv_sec) * 1000000 + tvNow.tv_usec -
            tvBegin.tv_usec;
          nReduce = nTimeTest - nDelay;
          fprintf (stderr, "\t nanosleep    %8u   %8u   %8d\n", nDelay,
                   nTimeTest, nReduce);
        }

      /*      test select */
      gettimeofday (&tvBegin, NULL);
      FD_ZERO (&rfds);
      FD_SET (fd, &rfds);
      tv.tv_sec = 0;
      tv.tv_usec = nDelay;
      ret = select (0, NULL, NULL, NULL, &tv);
      if (-1 == ret)
        {
          fprintf (stderr, " select error . errno=%d [%s]\n", errno,
                   strerror (errno));
        }
      gettimeofday (&tvNow, NULL);
      nTimeTest =
        (tvNow.tv_sec - tvBegin.tv_sec) * 1000000 + tvNow.tv_usec -
        tvBegin.tv_usec;
      nReduce = nTimeTest - nDelay;
      fprintf (stderr, "\t select       %8u   %8u   %8d\n", nDelay, nTimeTest,
               nReduce);

    }

return 0;
}

---------------------------------------------------------------------------------------------------------------------------------------------------

測試
IBM AIX 3.4 單CPU
        sleep 可以在多線程中使用,只阻塞本線程,不影響所屬進程中的其它線程
        不支持 nanosleep
        支持 usleep 和 select
        以下采用 gettimeofday 對 usleep 和 select 的實際精確情況進行測試分析
          function time(usec)    realTime      reduce
-------------------------------------------------------------------
         usleep         500000     500026         26
         nanosleep      500000   not support
         select         500000     500026         26
         usleep         100000     100021         21
         nanosleep      100000   not support
         select         100000     100025         25
         usleep          50000      50021         21
         nanosleep       50000   not support
         select          50000      50107        107
         usleep          10000      10099         99
         nanosleep       10000   not support
         select          10000      10025         25
         usleep           1000       1021         21
         nanosleep        1000   not support
         select           1000       1024         24
         usleep            900        920         20
         nanosleep         900   not support
         select            900       1024        124
         usleep            500        523         23
         nanosleep         500   not support
         select            500       1024        524
         usleep            100        119         19
         nanosleep         100   not support
         select            100       1023        923
         usleep             10         31         21
         nanosleep          10   not support
         select             10       1024       1014
         usleep              1         19         18
         nanosleep           1   not support
         select              1       1026       1025

       
    由此可以得出,在AIX 3.4下:
         select 只能精確到毫秒級別
         usleep 可以精確到微秒級
         在1毫秒以上,兩者的精確度基本一樣

同上,在 linux 2.4.20-8smp 雙CPU 下測試
          function time(usec)    realTime      reduce
-------------------------------------------------------------------
         usleep         500000     506453       6453
         nanosleep      500000     509930       9930
         select         500000     499990        -10
         usleep         100000     110023      10023
         nanosleep      100000     109955       9955
         select         100000      99992         -8
         usleep          50000      59971       9971
         nanosleep       50000      59990       9990
         select          50000      50025         25
         usleep          10000      19991       9991
         nanosleep       10000      19988       9988
         select          10000       9956        -44
         usleep           1000      19990      18990
         nanosleep        1000      19989      18989
         select           1000      10024       9024
         usleep            900      20009      19109
         nanosleep         900      19972      19072
         select            900       9943       9043
         usleep            500      19975      19475
         nanosleep         500      19971      19471
         select            500      10012       9512
         usleep            100      19975      19875
         nanosleep         100      19976      19876
         select            100       9943       9843
         usleep             10      19988      19978
         nanosleep          10      19961      19951
         select             10      10011      10001
         usleep              1      19978      19977
         nanosleep           1      19985      19984
         select              1       9932       9931
在 2.4.21-4.ELsmp #1 SMP 4 CPU 下測試
           function time(usec)    realTime      reduce
-------------------------------------------------------------------
         usleep         500000     501267       1267
         nanosleep      500000     509964       9964
         select         500000     499981        -19
         usleep         100000     109944       9944
         nanosleep      100000     109925       9925
         select         100000      99963        -37
         usleep          50000      59904       9904
         nanosleep       50000      59973       9973
         select          50000      49956        -44
         usleep          10000      19988       9988
         nanosleep       10000      20008      10008
         select          10000      10020         20
         usleep           1000      19988      18988
         nanosleep        1000      19980      18980
         select           1000       9943       8943
         usleep            900      19975      19075
         nanosleep         900      19986      19086
         select            900       9905       9005
         usleep            500      19989      19489
         nanosleep         500      19910      19410
         select            500      10000       9500
         usleep            100      19355      19255
         nanosleep         100      19902      19802
         select            100       9988       9888
         usleep             10      19977      19967
         nanosleep          10      19988      19978
         select             10       9943       9933
         usleep              1      20007      20006
         nanosleep           1      19947      19946
         select              1       9980       9979
        
由此可以得出如下結論,在 linux 2.4 下:
          1、支持 usleep,nanosleep,select
          2、select 的 精確度為 10毫秒。在10毫秒以上很精確
          3、usleep, nanosleep 很不精確

同樣,通過其它測試程序能得出如下結論:
          sleep 可以在多線程中使用,只阻塞本線程,不影響所屬進程中的其它線程

usleep()有有很大的問題

  1. 在一些平臺下不是線程安全,如HP-UX以及Linux
  2. usleep()會影響信號
  3. 在很多平臺,如HP-UX以及某些Linux下,當參數的值必須小于1 * 1000 * 1000也就是1秒,否則該函數會報錯,并且立即返回。
  4. 大部分平臺的幫助文檔已經明確說了,該函數是已經被舍棄的函數。

還好,POSIX規范中有一個很好用的函數,nanosleep(),該函數沒有usleep()的這些缺點,它的精度是納秒級。在Solaris的多線程環境下編譯器會自動把usleep()連接成nanosleep()

Linux下短延時推薦使用select函數.

Feedback

# re: 關于短延遲 sleep usleep nanosleep select[未登錄]  回復  更多評論   

2012-07-16 09:17 by jim
感謝分享,很好
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            鲁大师成人一区二区三区| 亚洲精选中文字幕| 久久婷婷久久| 久久久另类综合| 久久精品人人做人人综合 | 国产精品日韩精品| 国产精品欧美经典| 国产香蕉97碰碰久久人人| 狠狠色丁香久久婷婷综合丁香| 国产日本欧美一区二区| 国产主播精品| 亚洲激情婷婷| 亚洲欧美日韩国产中文在线| 欧美在线播放一区二区| 蜜臀av一级做a爰片久久| 最新日韩在线| 日韩视频免费观看| 欧美在线免费观看视频| 欧美精品在线免费播放| 国产网站欧美日韩免费精品在线观看 | 亚洲欧美春色| 玖玖玖国产精品| 日韩一区二区精品葵司在线| 欧美一区二区精品在线| 欧美成人日韩| 国产日本欧美一区二区三区在线 | 日韩视频免费大全中文字幕| 欧美一级黄色网| 亚洲国产精品va在线观看黑人| 中文日韩在线| 欧美成人精品1314www| 国产精品一区在线播放| 日韩亚洲欧美精品| 免费成人黄色| 亚洲嫩草精品久久| 欧美—级高清免费播放| 136国产福利精品导航| 香港久久久电影| 亚洲区免费影片| 久久亚洲春色中文字幕| 国产欧美日韩激情| 亚洲视频在线观看免费| 欧美粗暴jizz性欧美20| 羞羞漫画18久久大片| 欧美日韩视频在线| 国产三区精品| 午夜精品成人在线视频| 午夜一区二区三区在线观看| 欧美激情一区二区三区高清视频| 国产日韩欧美一区二区| 在线视频欧美一区| 亚洲高清视频中文字幕| 久久尤物电影视频在线观看| 国产婷婷色一区二区三区四区| 亚洲神马久久| av不卡在线观看| 欧美精品日本| 亚洲精品综合精品自拍| 欧美大片一区| 欧美xart系列高清| 亚洲黄色精品| 最新日韩av| 欧美精品一区二区在线播放| 在线观看亚洲精品| 欧美成人亚洲成人日韩成人| 久久综合九色99| 91久久精品美女| 亚洲国产高清高潮精品美女| 欧美成人免费全部观看天天性色| 亚洲精品美女久久7777777| 亚洲国产专区校园欧美| 欧美国产第二页| 亚洲最新在线视频| 宅男精品导航| 国产一区二区激情| 欧美粗暴jizz性欧美20| 欧美日韩国产综合在线| 亚洲欧美中文另类| 久久国产精品99精品国产| 韩国av一区二区| 免费高清在线一区| 欧美日韩p片| 午夜精品在线视频| 久久久精品国产免费观看同学 | 国产日韩在线亚洲字幕中文| 久久久久久伊人| 另类综合日韩欧美亚洲| 日韩视频免费在线| 亚洲性感美女99在线| 一色屋精品亚洲香蕉网站| 亚洲欧洲免费视频| 国产精品夜夜夜| 免费av成人在线| 欧美视频你懂的| 久久亚洲影音av资源网| 欧美激情91| 久久精品在线观看| 欧美成人综合一区| 久久国产精品99国产精| 欧美精品国产一区二区| 久久久福利视频| 欧美日韩精品免费观看视一区二区 | 久久综合狠狠综合久久综合88 | 国产精品美女久久久久av超清| 性欧美大战久久久久久久久| 久久亚洲精选| 午夜电影亚洲| 欧美国产综合一区二区| 久久大逼视频| 欧美日韩精品一区二区在线播放| 欧美亚洲综合久久| 欧美日本韩国一区| 免费91麻豆精品国产自产在线观看| 欧美日韩免费在线| 欧美大成色www永久网站婷| 国产精品免费一区二区三区在线观看| 老司机一区二区| 国产精品一二| 日韩亚洲视频在线| 亚洲精品在线三区| 久久久.com| 久久久福利视频| 国产精品亚洲综合色区韩国| 亚洲精品在线三区| 亚洲精品黄网在线观看| 久久久激情视频| 久久夜色精品国产欧美乱极品| 国产精品国产a级| 99国内精品| 日韩午夜免费视频| 欧美不卡高清| 亚洲福利视频二区| 1024精品一区二区三区| 久久精品国产99精品国产亚洲性色| 午夜精品久久久久久久久 | 欧美日本亚洲| 亚洲激情电影在线| 亚洲精品一区二区三区99| 久久综合99re88久久爱| 久久婷婷麻豆| 黄色亚洲精品| 久久夜色精品国产欧美乱极品| 久久婷婷综合激情| 狠狠色综合色区| 久久这里只有| 亚洲二区精品| 在线视频欧美精品| 国产精品每日更新| 午夜日韩在线| 欧美a一区二区| 亚洲国产成人精品久久久国产成人一区| 久久久精品性| 亚洲成人在线网站| 一区二区久久久久| 国产精品免费视频xxxx| 欧美一区二区| 欧美黄网免费在线观看| av成人黄色| 国产日韩精品一区二区| 久久乐国产精品| 99国产精品国产精品久久| 午夜亚洲视频| 在线观看久久av| 欧美精品v日韩精品v韩国精品v| 性欧美在线看片a免费观看| 国产亚洲一区二区在线观看| 亚洲欧美日韩国产一区| 久久人人超碰| 亚洲另类春色国产| 国产精品男人爽免费视频1| 久久国产毛片| 亚洲精品视频在线| 欧美一区=区| 亚洲精品1区| 国产伦精品一区二区三区高清版| 欧美在线日韩| 亚洲最新视频在线| 玖玖精品视频| 亚洲女同在线| 91久久在线观看| 国产视频在线一区二区 | 国产精品一区二区久久| 久久久精品网| 亚洲一区在线免费| 亚洲激情欧美激情| 久久视频在线免费观看| 亚洲天天影视| 在线观看亚洲精品视频| 国产精品99一区| 免费中文字幕日韩欧美| 欧美一级电影久久| 这里只有精品电影| 亚洲高清不卡av| 久色成人在线| 久久久av网站| 欧美一级日韩一级| 亚洲一区二区在线免费观看视频 | 亚洲福利视频专区| 国产欧美一区二区三区沐欲| 欧美日韩一区在线|