• <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)論排行榜

            性色欲网站人妻丰满中文久久不卡| 亚洲国产成人久久综合碰碰动漫3d| 国产精品亚洲综合专区片高清久久久 | 99久久国产亚洲高清观看2024 | 久久国产精品无码网站| 香蕉久久夜色精品国产2020| 人妻精品久久无码专区精东影业| 99久久精品无码一区二区毛片| 久久久久亚洲精品无码网址| 午夜精品久久久久久久久| 国产激情久久久久影院老熟女免费| 伊人精品久久久久7777| 九九久久99综合一区二区| 欧美亚洲国产精品久久久久| 久久久精品午夜免费不卡| 午夜欧美精品久久久久久久| 久久高清一级毛片| 精品久久久久久久| AV无码久久久久不卡网站下载| 一97日本道伊人久久综合影院| 色噜噜狠狠先锋影音久久| aaa级精品久久久国产片| 波多野结衣AV无码久久一区| 日产久久强奸免费的看| 青青国产成人久久91网| 色综合久久无码五十路人妻| 久久亚洲AV成人无码| 久久精品国产清自在天天线| 色综合色天天久久婷婷基地| 国产精品久久久久无码av | 成人亚洲欧美久久久久 | 精品一二三区久久aaa片| 欧美色综合久久久久久| 国产精品成人久久久久久久| 四虎国产精品免费久久5151| 久久99热国产这有精品| 99久久精品费精品国产| 国产午夜福利精品久久| 国产精品内射久久久久欢欢| 久久国产三级无码一区二区 | 久久久亚洲裙底偷窥综合|