• <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 閱讀(396) 評論(0)  編輯 收藏 引用 所屬分類: Linux(C++開發) (rss)

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久99中文字幕久久| 伊人久久一区二区三区无码| 色欲综合久久中文字幕网| 久久99国产综合精品免费| 久久精品成人免费网站| 久久久综合香蕉尹人综合网| 久久WWW免费人成一看片| 久久精品成人国产午夜| 亚洲国产精品狼友中文久久久| 欧美va久久久噜噜噜久久| 久久91这里精品国产2020| 久久无码中文字幕东京热| 国産精品久久久久久久| 亚洲AV乱码久久精品蜜桃| 久久久久国产视频电影| 国产人久久人人人人爽| 久久精品国产2020| 国内精品伊人久久久久网站| 亚洲国产精品无码久久久蜜芽| 老司机国内精品久久久久| 三上悠亚久久精品| 中文字幕精品久久| 国内精品免费久久影院| 欧美精品一区二区精品久久 | 久久777国产线看观看精品| 久久婷婷人人澡人人| 国产精品无码久久四虎| 91视频国产91久久久| 影音先锋女人AV鲁色资源网久久| 久久久久亚洲精品天堂久久久久久| 久久777国产线看观看精品| 国产一区二区三区久久精品| 久久99精品久久久久久hb无码 | 国产一区二区三区久久| 久久er99热精品一区二区| 麻豆成人久久精品二区三区免费| 国产成人精品三上悠亚久久| 亚洲精品无码久久千人斩| 97精品依人久久久大香线蕉97| 久久国产精品无| 99蜜桃臀久久久欧美精品网站|