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

            基友

            同行

            業界前輩

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            99久久国产综合精品网成人影院 | 久久不见久久见免费影院www日本| 一本一道久久a久久精品综合| 四虎影视久久久免费| 香蕉久久夜色精品升级完成 | 国产精品毛片久久久久久久| avtt天堂网久久精品| A级毛片无码久久精品免费| 国产精品99久久久久久宅男| 亚洲婷婷国产精品电影人久久| 99精品久久久久久久婷婷 | 久久久久亚洲Av无码专| 久久亚洲精品无码观看不卡| 亚洲精品美女久久久久99| 97超级碰碰碰碰久久久久| 久久国语露脸国产精品电影| 精品久久久久久国产免费了| 亚洲欧美伊人久久综合一区二区| 岛国搬运www久久| 久久精品国产亚洲av水果派| 日韩久久久久中文字幕人妻| 国产午夜精品理论片久久影视| 伊人久久大香线蕉无码麻豆| 99久久精品国产综合一区 | 久久激情五月丁香伊人| 99国产欧美久久久精品蜜芽 | 国产婷婷成人久久Av免费高清 | 亚洲综合精品香蕉久久网97 | 2020国产成人久久精品| 精品久久久久久久久久中文字幕| 国产精品久久久久jk制服| 欧洲成人午夜精品无码区久久| 日产久久强奸免费的看| 久久久艹| 亚洲欧美一级久久精品| 久久精品中文字幕大胸| 久久亚洲高清综合| 亚洲国产视频久久| 99久久无色码中文字幕人妻 | AAA级久久久精品无码区| 国产69精品久久久久9999|