• <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百分比計算方式

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


             top看到的cpu信息解釋的不是很清晰,就看下源碼怎么寫的吧。
                    程序很簡單,基本都在top.c里。
                    load里的cpu詳細信息代碼如下:
             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數量。
                    cpus_refresh函數里從/proc/stat文件里讀入cpu信息,然后裝入smpcpu里。smpcpu為大小為Cpu_tot+1個CPU_t成員的數組。
                    /proc/stat文件的頭幾行為:
            cpu %%
            cpu0 
            %%
            cpu1 
            %%
                    第一行的cpu信息裝入smpcpu[Cpu_tot],之后的cpu0\cpu1\...裝入smpcpu[0]\smpcpu[1\...。
                    View_CPUSUM這個由1鍵來控制的那個開關,開關關閉時只顯示smpcpu的Cpu_tot,開關開啟時顯示的是smpcpu的下標0~Cpu_tot-1的成員。即,top的默認在開頭顯示的cpu詳細信息顯示的是/proc/stat的第一行處理后,按下1鍵,顯示的時/proc/stat后續各cpu數據。
                    /proc/stat里都是數字,下邊看看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取的數據稱為一幀的數據,會從到CPU_t結構體的第一行成員里,上次的數據即上一幀的數據就拷到CPU_t的第二排帶_sav后綴的成員里,一一對應。
                    summaryhlp函數里計算我們想看的cpu各詳細指標的百分比。只取部分代碼或偽碼做演示:
             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 
                    每個進程占cpu百分比計算:
            1 Frame_tscale = 100.0f / ((float)Hertz * (float)et * (Rc.mode_irixps ? 1 : Cpu_tot));
            2 float u = (float)p->pcpu * Frame_tscale;
                    算的是兩幀之間總時間片數量,各進程占的時間片數量百分比。

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

            評論

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

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

            (float)p->pcpu 這個值是怎么計算出來的?是通過這個函數嗎procs_refresh。跟到這里找到readproc,又跟到proc_t*(*reader)(struct PROCTAB *restrict const, proc_t *restrict const);就找不到了。  回復  更多評論   

            <2013年4月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            留言簿(1)

            隨筆分類(77)

            隨筆檔案(58)

            me

            基友

            同行

            業界前輩

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            亚洲va中文字幕无码久久| 久久九九久精品国产| 久久国产精品成人片免费| 国产精品一久久香蕉国产线看观看 | 久久久久久九九99精品| 91精品国产色综合久久| 日本久久久久久中文字幕| 久久性精品| 粉嫩小泬无遮挡久久久久久| 久久久精品久久久久久| 精品国产一区二区三区久久久狼 | 久久天天婷婷五月俺也去| 国内精品久久久久久久97牛牛| 国内精品久久久久久麻豆| 麻豆一区二区99久久久久| 久久久久久久综合综合狠狠| 精品久久人妻av中文字幕| 模特私拍国产精品久久| 99久久免费只有精品国产| 久久综合精品国产二区无码| 亚洲午夜精品久久久久久app| 久久99国产综合精品女同| 久久99精品国产麻豆宅宅| 久久毛片免费看一区二区三区| 99久久免费国产精品热| 7777久久久国产精品消防器材| 久久久久国产一级毛片高清板| 久久91精品国产91久久小草| 久久无码人妻一区二区三区| 无夜精品久久久久久| 少妇久久久久久被弄到高潮| 办公室久久精品| 国产精品热久久毛片| 中文字幕亚洲综合久久2| 嫩草影院久久国产精品| AV无码久久久久不卡蜜桃| 久久久久人妻一区精品性色av| 伊人久久久AV老熟妇色| 人妻精品久久无码专区精东影业| 国产精品久久久久久久app| 中文字幕无码久久久|