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

Prayer

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

sleep usleep select 延時比較

Posted on 2008-08-21 19:18 Prayer 閱讀(2071) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX

 再論精確延時(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  可以在多線程中使用,只阻塞本線程,不影響所屬進程中的其它線程

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久一二三区| 国产一区观看| 亚洲午夜在线观看视频在线| 日韩视频三区| av成人黄色| 午夜欧美电影在线观看| 亚洲伦理中文字幕| 亚洲伦理在线观看| 亚洲欧美日韩另类| 久久久免费精品视频| 免费观看国产成人| 91久久精品日日躁夜夜躁国产| 欧美大片免费| 99综合精品| 国内精品免费在线观看| 欧美福利影院| 欧美日韩一区二区三区在线视频| 国产精品视频网址| 1769国内精品视频在线播放| 最新精品在线| 午夜亚洲精品| 欧美激情偷拍| 欧美一级大片在线观看| 欧美成人精品1314www| 国产精品久久久久国产精品日日| 狠狠色丁香久久婷婷综合丁香| 99视频热这里只有精品免费| 欧美在线视频不卡| 亚洲第一天堂无码专区| 在线视频中文亚洲| 美腿丝袜亚洲色图| 国产精品一区二区a| 亚洲免费久久| 亚洲欧美视频一区| 欧美精品亚洲精品| 狠狠综合久久av一区二区老牛| 一本色道久久加勒比88综合| 欧美激情精品久久久久久蜜臀| 欧美成人一区二区| 亚洲日本久久| 校园春色综合网| 欧美日韩国产一区二区| 国产尤物精品| 亚洲一二三区精品| 欧美福利视频网站| 亚洲国产婷婷香蕉久久久久久99 | 欧美视频官网| 国内激情久久| 欧美在线视频全部完| 99精品久久| 欧美激情在线有限公司| 亚洲国产免费| 久久在线免费| 久久激情中文| 欧美天堂亚洲电影院在线观看| 亚洲国产高清一区| 鲁大师影院一区二区三区| 亚洲欧美日韩电影| 国产精品伦子伦免费视频| 欧美福利一区| 亚洲国产高清在线| 欧美一二三视频| 99成人在线| 国产精品theporn| 一本久久综合| 一本色道久久综合| 国产精品成人v| 午夜精品一区二区三区电影天堂| 国产一区高清视频| 国产亚洲人成网站在线观看| 久久福利毛片| 欧美影院一区| 激情久久五月| 欧美aⅴ99久久黑人专区| 久久综合激情| 亚洲精品乱码久久久久久蜜桃91| 亚洲丰满在线| 欧美理论在线播放| 午夜精品久久久久久久男人的天堂| 一区二区三区高清| 国产麻豆日韩| 久久精品免费电影| 蜜桃av噜噜一区| 一本一本大道香蕉久在线精品| 亚洲无线视频| 国产亚洲日本欧美韩国| 欧美aⅴ一区二区三区视频| 欧美岛国激情| 欧美激情一区二区三区全黄| 亚洲天堂第二页| 午夜综合激情| 亚洲精品乱码| 午夜视频在线观看一区| **欧美日韩vr在线| 国内精品嫩模av私拍在线观看 | 亚洲黄色免费| 亚洲综合欧美| 久久综合婷婷| 亚洲字幕一区二区| 久久久精品一品道一区| 在线视频欧美日韩精品| 午夜精品偷拍| 亚洲乱码视频| 久久动漫亚洲| 亚洲欧美一区二区视频| 麻豆精品国产91久久久久久| 亚洲一区二区成人| 免费看的黄色欧美网站| 小黄鸭精品aⅴ导航网站入口| 麻豆成人av| 欧美一级理论性理论a| 欧美母乳在线| 久久天堂av综合合色| 久久综合久久美利坚合众国| 欧美日韩色一区| 蜜臀va亚洲va欧美va天堂| 国产精品免费一区二区三区观看| 女女同性精品视频| 国产欧美日韩亚洲| 亚洲视频axxx| 一个人看的www久久| 欧美成人黄色小视频| 免费高清在线视频一区·| 国产精品美女久久久久久久| 亚洲人成网站色ww在线| 亚洲国产视频一区| 久久久久久一区二区三区| 亚洲自拍偷拍福利| 欧美三级视频| 99精品视频一区| 在线视频欧美日韩精品| 欧美欧美在线| 亚洲激情欧美| 夜夜嗨av一区二区三区四区| 亚洲一区影音先锋| 亚洲女同同性videoxma| 欧美日韩一区二区三区四区五区| 亚洲第一区中文99精品| 亚洲国产综合在线| 麻豆国产va免费精品高清在线| 媚黑女一区二区| 好吊妞这里只有精品| 亚洲一卡久久| 亚洲精品五月天| 欧美一区二区| 久久久夜夜夜| 在线观看国产欧美| 牛牛影视久久网| 亚洲精品欧美日韩| 一区二区欧美在线| 欧美日韩一区二区精品| 夜夜躁日日躁狠狠久久88av| 亚洲欧美另类久久久精品2019| 欧美午夜大胆人体| 亚洲欧美国产不卡| 久久久久久久一区| 亚洲高清视频一区二区| 亚洲图片在线| 日韩一区二区精品| 亚洲男人第一av网站| 国产精品国产三级国产专播精品人 | 一区二区欧美在线| 国产精品丝袜91| 久久久精品tv| 欧美成人tv| 国产一区二区三区在线观看免费视频 | 国产精品最新自拍| 久久九九热re6这里有精品| 男同欧美伦乱| 亚洲精品国产精品乱码不99| 欧美日韩一区二区视频在线| 亚洲一区二区在线观看视频| 美国成人直播| 日韩亚洲欧美成人| 国产精品久久亚洲7777| 久久精品成人| 99ri日韩精品视频| 欧美aa在线视频| 西西人体一区二区| 在线看无码的免费网站| 欧美网站在线观看| 久久夜色精品| 日韩视频在线一区二区| 快射av在线播放一区| 亚洲免费在线电影| 亚洲国产一二三| 国产亚洲精品久| 欧美色欧美亚洲另类七区| 久久午夜电影网| 亚洲午夜久久久久久久久电影院 | 亚洲性av在线| 亚洲人成77777在线观看网| 欧美伊人久久久久久久久影院 | 亚洲在线观看免费| 亚洲第一色在线| 久久精品99国产精品酒店日本| 99热免费精品| 亚洲日本中文字幕区| 国产真实乱偷精品视频免| 国产精品久在线观看|