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

            程序設(shè)計(jì)入門--時(shí)間概念

            前言:Linux下的時(shí)間概念
            這一章我們學(xué)習(xí)Linux的時(shí)間表示和計(jì)算函數(shù)
            時(shí)間的表示
            時(shí)間的測(cè)量
            計(jì)時(shí)器的使用

            1。時(shí)間表示 在程序當(dāng)中,我們經(jīng)常要輸出系統(tǒng)當(dāng)前的時(shí)間,比如我們使用date命令
            的輸出結(jié)果.這個(gè)時(shí)候我們可以使用下面兩個(gè)函數(shù)

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


            time函數(shù)返回從1970年1月1日0點(diǎn)以來(lái)的秒數(shù).存儲(chǔ)在time_t結(jié)構(gòu)之中.不過(guò)這個(gè)函數(shù)的返
            回值對(duì)于我們來(lái)說(shuō)沒(méi)有什么實(shí)際意義.這個(gè)時(shí)候我們使用第二個(gè)函數(shù)將秒數(shù)轉(zhuǎn)化為字符串
            .. 這個(gè)函數(shù)的返回類型是固定的:一個(gè)可能值為. Thu Dec 7 14:58:59 2000 這個(gè)字符串
            的長(zhǎng)度是固定的為26
            2。時(shí)間的測(cè)量 有時(shí)候我們要計(jì)算程序執(zhí)行的時(shí)間.比如我們要對(duì)算法進(jìn)行時(shí)間分析
            ..這個(gè)時(shí)候可以使用下面這個(gè)函數(shù).

             
            1. #include <sys/time.h>    
            2.   
            3. int gettimeofday(struct timeval *tv,struct timezone *tz);    
            4. strut timeval {    
            5. long tv_sec; /* 秒數(shù) */    
            6. long tv_usec; /* 微秒數(shù) */    
            7. };    
            8. gettimeofday將時(shí)間保存在結(jié)構(gòu)tv之中.tz一般我們使用NULL來(lái)代替.    
            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. }    


            這個(gè)程序輸出函數(shù)的執(zhí)行時(shí)間,我們可以使用這個(gè)來(lái)進(jìn)行系統(tǒng)性能的測(cè)試,或者是函數(shù)算
            法的效率分析.在我機(jī)器上的一個(gè)輸出結(jié)果是: Used Time:0.556070
            3。計(jì)時(shí)器的使用 Linux操作系統(tǒng)為每一個(gè)進(jìn)程提供了3個(gè)內(nèi)部間隔計(jì)時(shí)器.
            ITIMER_REAL:減少實(shí)際時(shí)間.到時(shí)的時(shí)候發(fā)出SIGALRM信號(hào).
            ITIMER_VIRTUAL:減少有效時(shí)間(進(jìn)程執(zhí)行的時(shí)間).產(chǎn)生SIGVTALRM信號(hào).
            ITIMER_PROF:減少進(jìn)程的有效時(shí)間和系統(tǒng)時(shí)間(為進(jìn)程調(diào)度用的時(shí)間).這個(gè)經(jīng)常和上面一
            個(gè)使用用來(lái)計(jì)算系統(tǒng)內(nèi)核時(shí)間和用戶時(shí)間.產(chǎn)生SIGPROF信號(hào).
            具體的操作函數(shù)是:

             
            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函數(shù)得到間隔計(jì)時(shí)器的時(shí)間值.保存在value中 setitimer函數(shù)設(shè)置間隔計(jì)時(shí)器
            的時(shí)間值為newval.并將舊值保存在oldval中. which表示使用三個(gè)計(jì)時(shí)器中的哪一個(gè).
            itimerval結(jié)構(gòu)中的it_value是減少的時(shí)間,當(dāng)這個(gè)值為0的時(shí)候就發(fā)出相應(yīng)的信號(hào)了. 然
            后設(shè)置為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 "時(shí)間已經(jīng)過(guò)去了兩秒鐘\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. }    


            這個(gè)程序每執(zhí)行兩秒中之后會(huì)輸出一個(gè)提示.

            posted on 2008-04-16 09:12 RedLight 閱讀(401) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Linux(C++開(kāi)發(fā)) (rss)

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

            導(dǎo)航

            統(tǒng)計(jì)

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊(cè)

            My Friend

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            女人香蕉久久**毛片精品| 久久久中文字幕| 99久久伊人精品综合观看| 青青草原综合久久| 久久精品国产精品亚洲精品 | 色综合久久综合网观看| 大美女久久久久久j久久| 日韩中文久久| 丰满少妇高潮惨叫久久久| 久久av免费天堂小草播放| 亚洲国产另类久久久精品小说| 久久国产精品成人免费| 久久国产高清一区二区三区| 少妇久久久久久被弄高潮| 久久精品亚洲精品国产欧美| 麻豆一区二区99久久久久| 香蕉99久久国产综合精品宅男自| 亚洲午夜久久久久久久久电影网 | 精品综合久久久久久97| 久久精品亚洲乱码伦伦中文 | 热99re久久国超精品首页| 久久99这里只有精品国产| 久久久久99精品成人片三人毛片| 亚洲AV日韩精品久久久久久久| 久久电影网| 久久www免费人成看国产片| 久久精品国产半推半就| 奇米影视7777久久精品| 久久中文字幕人妻熟av女| 久久性精品| 国产69精品久久久久久人妻精品| 夜夜亚洲天天久久| 亚洲国产成人久久综合一区77| 伊人久久五月天| 思思久久精品在热线热| 一级a性色生活片久久无少妇一级婬片免费放 | 亚洲v国产v天堂a无码久久| 久久精品成人免费观看97| 久久精品亚洲欧美日韩久久| 精品久久久久久无码中文字幕 | 久久99精品久久久久久秒播|