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

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

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            伊人久久五月天| 久久青青国产| 久久97久久97精品免视看秋霞| 国产国产成人久久精品| 久久久综合九色合综国产| 国产精品国色综合久久| 国产精品成人精品久久久 | 亚洲精品美女久久777777| 奇米影视7777久久精品人人爽| 精品久久久久久国产| 天天综合久久一二三区| 少妇久久久久久被弄高潮| 国产美女久久久| 久久久无码人妻精品无码| 综合久久给合久久狠狠狠97色| 狠狠精品久久久无码中文字幕| 久久精品国产久精国产一老狼| 2021国内久久精品| 国产精品女同一区二区久久| 久久无码AV一区二区三区| 久久久久久久尹人综合网亚洲| 亚洲伊人久久综合中文成人网| 蜜臀av性久久久久蜜臀aⅴ| 久久午夜夜伦鲁鲁片免费无码影视| 久久精品国产亚洲AV香蕉| 伊人久久大香线焦AV综合影院 | 欧美一区二区三区久久综| 婷婷久久五月天| 久久亚洲精品成人AV| 热久久国产精品| 亚洲欧洲久久久精品| 欧洲人妻丰满av无码久久不卡| 亚洲精品白浆高清久久久久久| 伊人久久综合热线大杳蕉下载| 久久久国产乱子伦精品作者| 欧美喷潮久久久XXXXx| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久96国产精品久久久| 97久久综合精品久久久综合| 99久久99久久精品国产| 精品久久久噜噜噜久久久|