• <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>

            程序設計入門--時間概念

            前言:Linux下的時間概念
            這一章我們學習Linux的時間表示和計算函數
            時間的表示
            時間的測量
            計時器的使用

            1。時間表示 在程序當中,我們經常要輸出系統當前的時間,比如我們使用date命令
            的輸出結果.這個時候我們可以使用下面兩個函數

             
            1. #include <time.h>    
            2.   
            3. time_t time(time_t *tloc);    
            4. char *ctime(const time_t *clock);    


            time函數返回從1970年1月1日0點以來的秒數.存儲在time_t結構之中.不過這個函數的返
            回值對于我們來說沒有什么實際意義.這個時候我們使用第二個函數將秒數轉化為字符串
            .. 這個函數的返回類型是固定的:一個可能值為. Thu Dec 7 14:58:59 2000 這個字符串
            的長度是固定的為26
            2。時間的測量 有時候我們要計算程序執行的時間.比如我們要對算法進行時間分析
            ..這個時候可以使用下面這個函數.

             
            1. #include <sys/time.h>    
            2.   
            3. int gettimeofday(struct timeval *tv,struct timezone *tz);    
            4. strut timeval {    
            5. long tv_sec; /* 秒數 */    
            6. long tv_usec; /* 微秒數 */    
            7. };    
            8. gettimeofday將時間保存在結構tv之中.tz一般我們使用NULL來代替.    
            9. [codes=c]   
            10. #include <sys/time.h<    
            11. #include <stdio.h<    
            12. #include <math.h<    
            13. void function()    
            14. {    
            15. unsigned int i,j;    
            16. double y;    
            17. for(i=0;i<1000;i++)    
            18. for(j=0;j<1000;j++)    
            19. y=sin((double)i);    
            20. }    
            21. main()    
            22. {    
            23. struct timeval tpstart,tpend;    
            24. float timeuse;    
            25. gettimeofday(&tpstart,NULL);    
            26. function();    
            27. gettimeofday(&tpend,NULL);    
            28. timeuse=1000000*(tpend.tv_sec-tpstart.tv_sec)+    
            29. tpend.tv_usec-tpstart.tv_usec;    
            30. timeuse/=1000000;    
            31. printf("Used Time:%f\n",timeuse);    
            32. exit(0);    
            33. }    


            這個程序輸出函數的執行時間,我們可以使用這個來進行系統性能的測試,或者是函數算
            法的效率分析.在我機器上的一個輸出結果是: Used Time:0.556070
            3。計時器的使用 Linux操作系統為每一個進程提供了3個內部間隔計時器.
            ITIMER_REAL:減少實際時間.到時的時候發出SIGALRM信號.
            ITIMER_VIRTUAL:減少有效時間(進程執行的時間).產生SIGVTALRM信號.
            ITIMER_PROF:減少進程的有效時間和系統時間(為進程調度用的時間).這個經常和上面一
            個使用用來計算系統內核時間和用戶時間.產生SIGPROF信號.
            具體的操作函數是:

             
            1. #include <sys/time.h>    
            2. int getitimer(int which,struct itimerval *value);    
            3. int setitimer(int which,struct itimerval *newval,    
            4. struct itimerval *oldval);    
            5. struct itimerval {    
            6. struct timeval it_interval;    
            7. struct timeval it_value;    
            8. }    


            getitimer函數得到間隔計時器的時間值.保存在value中 setitimer函數設置間隔計時器
            的時間值為newval.并將舊值保存在oldval中. which表示使用三個計時器中的哪一個.
            itimerval結構中的it_value是減少的時間,當這個值為0的時候就發出相應的信號了. 然
            后設置為it_interval值.

             
            1. #include <sys/time.h>    
            2. #include <stdio.h>    
            3. #include <unistd.h>    
            4. #include <signal.h>    
            5. #include <string.h>    
            6. #define PROMPT "時間已經過去了兩秒鐘\n\a"    
            7. char *prompt=PROMPT;    
            8. unsigned int len;    
            9. void prompt_info(int signo)    
            10. {    
            11. write(STDERR_FILENO,prompt,len);    
            12. }    
            13. void init_sigaction(void)    
            14. {    
            15. struct sigaction act;    
            16. act.sa_handler=prompt_info;    
            17. act.sa_flags=0;    
            18. sigemptyset(&act.sa_mask);    
            19. sigaction(SIGPROF,&act,NULL);    
            20. }    
            21. void init_time()    
            22. {    
            23. struct itimerval value;    
            24. value.it_value.tv_sec=2;    
            25. value.it_value.tv_usec=0;    
            26. value.it_interval=value.it_value;    
            27. setitimer(ITIMER_PROF,&value,NULL);    
            28. }    
            29. int main()    
            30. {    
            31. len=strlen(prompt);    
            32. init_sigaction();    
            33. init_time();    
            34. while(1);    
            35. exit(0);    
            36. }    


            這個程序每執行兩秒中之后會輸出一個提示.

            posted on 2008-04-16 09:12 RedLight 閱讀(408) 評論(0)  編輯 收藏 引用 所屬分類: Linux(C++開發) (rss)

            <2008年4月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            色青青草原桃花久久综合| 亚洲一区中文字幕久久| 婷婷伊人久久大香线蕉AV| 精品久久久久久久| 久久久久亚洲精品无码网址| 中文字幕无码久久人妻| 国内精品久久久久影院优| 精品一久久香蕉国产线看播放 | 国产午夜久久影院| 合区精品久久久中文字幕一区| AAA级久久久精品无码片| 欧美午夜A∨大片久久| 99久久精品国产毛片| 伊人久久大香线蕉av不变影院| 久久国产精品波多野结衣AV| 久久国产免费观看精品3| 久久中文字幕人妻丝袜| 久久久久国色AV免费看图片| 99久久无码一区人妻a黑| 久久精品国产日本波多野结衣| 久久久久久亚洲精品不卡| 色综合久久最新中文字幕| 久久91精品国产91久久户| 国产精品亚洲综合久久| 亚洲国产日韩欧美综合久久| 久久精品中文字幕一区| 国产精品一区二区久久精品无码| 久久精品国产网红主播| 亚洲AV无码1区2区久久| 无码专区久久综合久中文字幕| 亚洲伊人久久综合中文成人网| 久久久久亚洲AV综合波多野结衣| 久久艹国产| 精品人妻伦九区久久AAA片69| 国产午夜精品久久久久九九电影| 久久亚洲国产中v天仙www| 久久精品这里热有精品| 亚洲一本综合久久| 午夜不卡888久久| 精品久久久久久无码中文野结衣 | 久久国产乱子精品免费女|