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

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            人妻无码αv中文字幕久久| 精品无码久久久久久午夜| 亚洲一区中文字幕久久| 99久久国产免费福利| 久久久久久A亚洲欧洲AV冫| 久久亚洲国产精品成人AV秋霞| 一本一道久久a久久精品综合| 亚洲精品蜜桃久久久久久| 欧美综合天天夜夜久久| 久久婷婷五月综合97色直播| 成人资源影音先锋久久资源网| 午夜精品久久影院蜜桃| 久久久久亚洲av无码专区导航| 久久久久久极精品久久久| 99久久无码一区人妻a黑| 亚洲色欲久久久久综合网| 国产亚洲美女精品久久久久狼| 99久久做夜夜爱天天做精品| 99久久婷婷国产综合精品草原 | 久久久无码精品亚洲日韩京东传媒| 久久久久久久女国产乱让韩| 久久99热这里只有精品国产| 久久久久久毛片免费播放| 亚洲综合久久久| 久久亚洲精品无码播放| 99久久精品无码一区二区毛片| 久久国产精品成人片免费| 国产成人无码精品久久久性色| 欧美一级久久久久久久大| 久久精品亚洲乱码伦伦中文| 精品久久久久久久久中文字幕| 中文字幕日本人妻久久久免费 | 中文精品99久久国产 | 久久亚洲国产欧洲精品一| 99国产精品久久| 欧美一区二区精品久久| 人人狠狠综合久久亚洲88| 亚洲天堂久久精品| 国产激情久久久久影院老熟女| 国产欧美久久久精品| 久久综合综合久久97色|