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

            Sheppard Y

            keep thinking keep coding.

            top里顯示的cpu百分比計(jì)算方式

            2016-07-11 日更新
            此篇博客已經(jīng)遷移到新博客,并做行文檢查和優(yōu)化排版:
            http://blog.clawz.me/2013/11/07/13-top-source/


             top看到的cpu信息解釋的不是很清晰,就看下源碼怎么寫的吧。
                    程序很簡(jiǎn)單,基本都在top.c里。
                    load里的cpu詳細(xì)信息代碼如下:
             1 smpcpu = cpus_refresh(smpcpu);
             2 
             3 if (CHKw(Curwin, View_CPUSUM)) {
             4         // display just the 1st /proc/stat line
             5         summaryhlp(&smpcpu[Cpu_tot], "Cpu(s):");
             6 else {
             7         int i;
             8         char tmp[SMLBUFSIZ];
             9         // display each cpu's states separately
            10         for (i = 0; i < Cpu_tot; i++) {
            11                 snprintf(tmp, sizeof(tmp), "Cpu%-3d:", smpcpu[i].id);
            12                 summaryhlp(&smpcpu[i], tmp);
            13         }
            14 }
                    
                    Cpu_tot為cpu數(shù)量。
                    cpus_refresh函數(shù)里從/proc/stat文件里讀入cpu信息,然后裝入smpcpu里。smpcpu為大小為Cpu_tot+1個(gè)CPU_t成員的數(shù)組。
                    /proc/stat文件的頭幾行為:
            cpu %%
            cpu0 
            %%
            cpu1 
            %%
                    第一行的cpu信息裝入smpcpu[Cpu_tot],之后的cpu0\cpu1\...裝入smpcpu[0]\smpcpu[1\...。
                    View_CPUSUM這個(gè)由1鍵來(lái)控制的那個(gè)開(kāi)關(guān),開(kāi)關(guān)關(guān)閉時(shí)只顯示smpcpu的Cpu_tot,開(kāi)關(guān)開(kāi)啟時(shí)顯示的是smpcpu的下標(biāo)0~Cpu_tot-1的成員。即,top的默認(rèn)在開(kāi)頭顯示的cpu詳細(xì)信息顯示的是/proc/stat的第一行處理后,按下1鍵,顯示的時(shí)/proc/stat后續(xù)各cpu數(shù)據(jù)。
                    /proc/stat里都是數(shù)字,下邊看看top里顯示的百分比怎么算的。
                    CPU_t的定義:
             1 // These typedefs attempt to ensure consistent 'ticks' handling
             2 typedef unsigned long long TIC_t;
             3 typedef          long long SIC_t;
             4 
             5 // This structure stores a frame's cpu tics used in history
             6 // calculations.  It exists primarily for SMP support but serves
             7 // all environments.
             8 typedef struct CPU_t {
             9         TIC_t u, n, s, i, w, x, y, z; // as represented in /proc/stat
            10         TIC_t u_sav, s_sav, n_sav, i_sav, w_sav, x_sav, y_sav, z_sav; // in the order of our display
            11         unsigned id;  // the CPU ID number
            12 } CPU_t;
                    每次從/proc/stat取的數(shù)據(jù)稱為一幀的數(shù)據(jù),會(huì)從到CPU_t結(jié)構(gòu)體的第一行成員里,上次的數(shù)據(jù)即上一幀的數(shù)據(jù)就拷到CPU_t的第二排帶_sav后綴的成員里,一一對(duì)應(yīng)。
                    summaryhlp函數(shù)里計(jì)算我們想看的cpu各詳細(xì)指標(biāo)的百分比。只取部分代碼或偽碼做演示:
             1 SIC_t u_frme, s_frme, n_frme, i_frme, w_frme, x_frme, y_frme, z_frme, tot_frme, tz;
             2 float scale;
             3 u_frme = cpu->- cpu->u_sav;
             4 s_frme = cpu->- cpu->s_sav;
             5 
             6 tot_frme = u_frme + s_frme + n_frme + i_frme + w_frme + x_frme + y_frme + z_frme;
             7 if (tot_frme < 1) tot_frme = 1;
             8 scale = 100.0 / (float)tot_frme;
             9 
            10 us% = (float)u_frme * scale;
            11 sy% = (float)s_frme * scale;
            12 
            13 cpu->u_sav = cpu->u;
            14 cpu->s_sav = cpu->s;
            15 
                    每個(gè)進(jìn)程占cpu百分比計(jì)算:
            1 Frame_tscale = 100.0f / ((float)Hertz * (float)et * (Rc.mode_irixps ? 1 : Cpu_tot));
            2 float u = (float)p->pcpu * Frame_tscale;
                    算的是兩幀之間總時(shí)間片數(shù)量,各進(jìn)程占的時(shí)間片數(shù)量百分比。

            posted on 2013-11-07 19:20 Sheppard Y 閱讀(2491) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 開(kāi)源

            評(píng)論

            # re: top里顯示的cpu百分比計(jì)算方式 2014-12-11 15:50 idoplay

            樓主好,我最近也在看top源代碼,有好多不懂得地方想請(qǐng)教一下。
            就是每個(gè)進(jìn)程占用的CPU百分比的計(jì)算方法這里,
            Frame_tscale = 100.0f / ((float)Hertz * (float)et * (Rc.mode_irixps ? 1 : Cpu_tot));
            這個(gè)的意思指的是CPU數(shù)量?Rc.mode_irixps ? 1 : Cpu_tot,為什么是1 呢?
            float u = (float)p->pcpu * Frame_tscale; 這句的意思是指進(jìn)程占用的單個(gè)CPU的百分比嗎。這句后面是if (u > pcpu_max_value) u = pcpu_max_value; 我看pcpu_max_value被定義為99.9,意思是說(shuō),進(jìn)程的cpu占用率超過(guò)99.9的時(shí)候,就讓它的占用率為99.9 ,難道進(jìn)程的CPU占用率不能為100%嗎,并且什么情況會(huì)超過(guò)100%呢?

            (float)p->pcpu 這個(gè)值是怎么計(jì)算出來(lái)的?是通過(guò)這個(gè)函數(shù)嗎procs_refresh。跟到這里找到readproc,又跟到proc_t*(*reader)(struct PROCTAB *restrict const, proc_t *restrict const);就找不到了。  回復(fù)  更多評(píng)論   

            <2013年12月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導(dǎo)航

            統(tǒng)計(jì)

            留言簿(1)

            隨筆分類(77)

            隨筆檔案(58)

            me

            基友

            同行

            業(yè)界前輩

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            少妇内射兰兰久久| 久久亚洲国产精品五月天婷| 人妻无码中文久久久久专区| 97久久超碰国产精品旧版| 久久99精品国产99久久6| 久久人人爽人人爽人人片AV东京热 | 伊人久久成人成综合网222| 久久久亚洲欧洲日产国码二区| 久久青草国产精品一区| 日韩欧美亚洲综合久久 | 国产精自产拍久久久久久蜜| 久久夜色精品国产亚洲av| 久久精品一本到99热免费| 青青草原综合久久大伊人导航| 亚洲精品午夜国产VA久久成人| 久久91精品国产91久久麻豆| 亚洲午夜福利精品久久| 欧美激情精品久久久久| 久久久久人妻一区精品色| 久久人妻无码中文字幕| 久久亚洲电影| 久久精品国产亚洲Aⅴ香蕉| 好久久免费视频高清| 热re99久久精品国99热| 狠狠色噜噜色狠狠狠综合久久| 国产日韩久久久精品影院首页| 色欲久久久天天天综合网| 色综合久久久久综合99| 精品无码人妻久久久久久| 国产91色综合久久免费分享| 亚洲国产另类久久久精品小说| 国产成人综合久久精品尤物| 青青草原综合久久| 久久九九亚洲精品| 色综合久久综精品| 91久久香蕉国产熟女线看| 999久久久免费国产精品播放| 久久精品国产亚洲网站| 久久精品一区二区国产| 亚洲国产精品久久久久婷婷老年 | 香蕉久久影院|