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

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

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产午夜精品久久久久九九电影| 久久九色综合九色99伊人| 亚洲午夜久久久久久久久电影网| 色综合久久久久综合体桃花网| 久久久久亚洲精品天堂| 精品久久久久久久中文字幕| 久久精品桃花综合| 91麻精品国产91久久久久| 色8激情欧美成人久久综合电| 伊人久久大香线蕉综合影院首页| 久久九九全国免费| 久久一日本道色综合久久| 久久高潮一级毛片免费| 国产成人久久精品激情| 久久久久久久久66精品片| 久久99亚洲综合精品首页| 人妻精品久久久久中文字幕一冢本| 亚洲伊人久久大香线蕉苏妲己| 人人妻久久人人澡人人爽人人精品| 国内精品久久久久影院日本| 免费一级做a爰片久久毛片潮| 久久精品一本到99热免费| 狠狠色丁香婷婷久久综合五月| 久久综合九色综合欧美狠狠| 亚洲精品乱码久久久久久| 久久天天躁狠狠躁夜夜不卡| 国产精品永久久久久久久久久| av无码久久久久久不卡网站| 亚洲午夜久久久久久久久电影网 | 2021久久精品国产99国产精品| 日本久久久久久久久久| 精品99久久aaa一级毛片| 国产精品久久久久一区二区三区| 久久午夜羞羞影院免费观看| 国产成人精品综合久久久久| 青青草原综合久久大伊人| 伊人热热久久原色播放www| 理论片午午伦夜理片久久| 人妻丰满?V无码久久不卡| 怡红院日本一道日本久久 | 精品久久久久香蕉网|