亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2979 | 回復(fù): 6
打印 上一主題 下一主題

關(guān)于定時(shí)器的問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2011-07-27 17:44 |只看該作者 |倒序?yàn)g覽
本帖最后由 LinuxJoin 于 2011-07-27 17:46 編輯

問題是這樣的,實(shí)現(xiàn)個(gè)timer定時(shí)器,200毫秒定時(shí)調(diào)用handler函數(shù) 打印信息,可是不知道這個(gè)timer與主線程main是什么關(guān)系,是兩個(gè)線程嗎?
  1. #include <stdio.h>
  2. #include <unistd.h>
  3. #include <signal.h>
  4. #include <stdlib.h>
  5. #include <time.h>

  6. #define rdtsc(low,high) __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high))



  7. void handler (int sig, siginfo_t * extra, void *cruft)
  8. {
  9.   static last_i=0;
  10.   unsigned int i, j;
  11.   rdtsc(i,j);
  12.   printf ("time:%u, %u, [%u] %uHZ \n", j, i, i-last_i, (i-last_i)*10/1000000);
  13.   last_i = i;
  14. }

  15. int main ()
  16. {
  17.         timer_t tt;
  18.   int i=0;
  19.   sigset_t sigset;

  20.   sigfillset (&sigset);
  21.   sigdelset (&sigset, SIGRTMIN);
  22.   sigprocmask (SIG_SETMASK, &sigset, NULL);

  23.   struct sigaction sa;
  24.   sigfillset (&sa.sa_mask);
  25.   sa.sa_flags = SA_SIGINFO;
  26.   sa.sa_sigaction = handler;

  27.   if (sigaction (SIGRTMIN, &sa, NULL) < 0)
  28.   {
  29.     perror ("sigaction failed ");
  30.     exit (-1);
  31.   }

  32.   struct sigevent timer_event;
  33.   struct itimerspec timer;

  34.   timer.it_value.tv_sec = 0;
  35.   timer.it_value.tv_nsec = 200 * 1000 * 1000;
  36.   timer.it_interval.tv_sec = 0;
  37.   timer.it_interval.tv_nsec = 200 * 1000 * 1000;

  38.   timer_event.sigev_notify = SIGEV_SIGNAL;
  39.   timer_event.sigev_signo = SIGRTMIN;
  40.   timer_event.sigev_value.sival_ptr = (void *) &tt;

  41.   if (timer_create (CLOCK_REALTIME, &timer_event, &tt) < 0)
  42.   {
  43.     perror ("timer_create failed");
  44.     exit (-1);
  45.   }

  46.   if (timer_settime (tt, 0, &timer, NULL) < 0)
  47.   {
  48.     perror ("timer_settime failed");
  49.     exit (-1);
  50.   }
  51.         while(1)
  52.         {
  53.                  sleep(2);
  54.                  printf("sleep 2 seconds.\n");
  55.         }
  56.   return 0;
  57. }

復(fù)制代碼
為什么上面代碼運(yùn)行的結(jié)果是
time:21400, 86281621, [86281621] 862HZ
sleep 2 seconds.
time:21400, 670689030, [584407409] 1549HZ
sleep 2 seconds.
time:21400, 1258047490, [587358460] 1578HZ
sleep 2 seconds.
time:21400, 1845329486, [587281996] 1577HZ
sleep 2 seconds.
time:21400, 2432350852, [587021366] 1575HZ
.
.
.
而不是 handler被調(diào)用10次,即打印time 10次,然后sleep 2 seconds 一次
小弟感覺結(jié)果應(yīng)該是這樣的
time:21400, 2432350852, [587021366] 1575HZ
time:21400, 2432350852, [587021366] 1575HZ
.
.
.(10次)
sleep 2 seconds.
.
.
.

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2011-07-28 10:31 |只看該作者
今天頂起,忘大俠們指點(diǎn)

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2011-07-28 15:20 |只看該作者
我的機(jī)器上運(yùn)行:
tuxedo@firefly ~]$ cd /bea/wangyy/mysrc/timer;/bea/wangyy/mysrc/timer/timer-dow
n
sleep 2 seconds.
sleep 2 seconds.
sleep 2 seconds.

。。。。
什么世道呀。明明一開始運(yùn)行跟你一樣的。后來呢,就這樣了。

。。。。
菜鳥揣測:你的進(jìn)程sleep了200毫秒后,被系統(tǒng)的信號SIGEV_SIGNAL喊醒了。
沒有睡夠2秒鐘。就起來print了。
建議把時(shí)鐘調(diào)整為2毫秒,10秒,分別試下。看看是不是這個(gè)樣子。

是不是在sleep前可以屏蔽信號SIGEV_SIGNAL,sleep后放開。
就能達(dá)到你要的效果。

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2011-07-29 10:06 |只看該作者
我的機(jī)器上是因?yàn)閱拥臎]有關(guān)閉,導(dǎo)致后來就抓不到你程序里的信號了。
每次測試完了,要手工把那些子進(jìn)程都kill。

目標(biāo):驗(yàn)證sleep會不會被SIGRTMIN喚醒。

測試:
1、定時(shí)器200毫秒。sleep2秒。
   結(jié)果:如樓主一樣,每200毫秒打印time:信息,緊跟著打印sleep2信息。

2、定時(shí)器20毫秒。sleep2秒。
   結(jié)果:打印結(jié)果類似,輸入速度快多了。原因:是sleep被吵醒的更頻繁了

3、定時(shí)器2秒+200毫秒,sleep2秒。
   結(jié)果:一個(gè)2秒的sleep輸出。(沒被吵醒)
        跟著一個(gè)timer輸出和sleep輸出。(被200毫秒吵醒)

---------------------------------------
嗯。我對我的揣測很滿意。

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2011-07-29 10:14 |只看該作者
i=0;  
        while (1)
        {
                for (i=0;i<10;i++)
                        {sleep(1);}  //被吵醒10次,會輸出10次time信息.
                   
               
                printf("sleep 2 seconds.\n");      //被200毫秒的鬧鐘叫醒10次后,估計(jì)為2秒
                                   
            
        }

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2011-07-29 10:18 |只看該作者
這樣的代碼就會達(dá)到你要的效果。
10次time輸出。
一次2秒信息輸出。

個(gè)人認(rèn)為,你應(yīng)該用獲得timer時(shí)間來寫,而不是用sleep。

偽碼:

//獲得timer的時(shí)間,作為lastsec
lastsec = get timer
while(1)
{
       //獲得timer的時(shí)間
     nowsec = get timer
      //如果超過2秒
     if(nowsec - lastsec == 2)
               輸出:2秒過去了。      
}

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2011-07-29 11:09 |只看該作者
#include <stdio.h>

#include <unistd.h>

#include <signal.h>

#include <stdlib.h>

#include <time.h>



#define rdtsc(low,high) __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high))




//down add by me
long lastsec,lastmsec;   //上一時(shí)間:秒、毫秒
long nowsec,nowmsec;     //這一時(shí)間:秒、毫秒
//up add by me   

void handler (int sig, siginfo_t * extra, void *cruft)

{

  static int last_i=0;

  unsigned int i, j;

  rdtsc(i,j);

  printf ("time:%u, %u, [%u] %uHZ \n", j, i, i-last_i, (i-last_i)*10/1000000);

  last_i = i;

//down add by me
// 計(jì)秒
   nowmsec += 200 * 1000 *1000;   
   if(nowmsec >= 1000*1000*1000)
                   {nowsec+=1;
         nowmsec=0;
        }
//   printf("nowsec:%ld,nowmsec:%ld\n",nowsec,nowmsec);
//up add by me   
   
}



int main ()

{

  timer_t tt;

  int i=0,j=0;

  sigset_t sigset;



  sigfillset (&sigset);

  sigdelset (&sigset, SIGRTMIN);

  sigprocmask (SIG_SETMASK, &sigset, NULL);



  struct sigaction sa;

  sigfillset (&sa.sa_mask);

  sa.sa_flags = SA_SIGINFO;

  sa.sa_sigaction = handler;



  if (sigaction (SIGRTMIN, &sa, NULL) < 0)

  {

    perror ("sigaction failed ");

    exit (-1);

  }



  struct sigevent timer_event;

  struct itimerspec timer;



  timer.it_value.tv_sec = 0;

  timer.it_value.tv_nsec = 200 * 1000 *1000;

  timer.it_interval.tv_sec = 0;

  timer.it_interval.tv_nsec = 200 * 1000 *1000;



  timer_event.sigev_notify = SIGEV_SIGNAL;

  timer_event.sigev_signo = SIGRTMIN;

  timer_event.sigev_value.sival_ptr = (void *) &tt;



  if (timer_create (CLOCK_REALTIME, &timer_event, &tt) < 0)

  {

    perror ("timer_create failed");

    exit (-1);

  }



  if (timer_settime (tt, 0, &timer, NULL) < 0)

  {

    perror ("timer_settime failed");

    exit (-1);

  }
  
  //down add by me
     //獲得timer的時(shí)間,作為last時(shí)間
          timer_gettime(tt,&timer);
        lastsec = timer.it_value.tv_sec;
    lastmsec = timer.it_value.tv_nsec;
    //now時(shí)間開始走
    nowsec = lastsec; nowmsec = lastmsec;
  //up add by me  
   
        while(1)
        {
            //down add by me
                   //如果超過2秒
                //printf("nowsec:%ld,lastsec:%ld.\n",nowsec,lastsec);
                        if( (nowsec-lastsec) == 2)
             {        //輸出:2秒過去了。      
                printf("2 seconds is pass\n");
                lastsec = nowsec;
                lastmsec = nowmsec;
             }
                //up add by me  
        }
       
        

  return 0;

}
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP