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

            閱讀排行榜

            久久人人爽人人爽人人片AV麻豆 | 国产欧美久久久精品| 99久久婷婷免费国产综合精品| 久久香蕉国产线看观看精品yw| 99热热久久这里只有精品68| 亚洲国产香蕉人人爽成AV片久久| 一本色道久久99一综合| 国内精品伊人久久久久影院对白 | 精品久久综合1区2区3区激情| 精品久久久无码人妻中文字幕| 久久国产精品久久| 国内精品人妻无码久久久影院导航| 青青热久久综合网伊人| 亚洲欧美伊人久久综合一区二区 | 91久久精品无码一区二区毛片| 久久青青色综合| 天天做夜夜做久久做狠狠| 丁香狠狠色婷婷久久综合| 亚洲欧美日韩中文久久| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久毛片一区二区| 国产免费久久久久久无码| 久久精品国产亚洲AV无码偷窥| 伊人伊成久久人综合网777| 污污内射久久一区二区欧美日韩| 狠狠精品久久久无码中文字幕 | 51久久夜色精品国产| 国内精品久久久久影院网站| 久久久久九九精品影院| 久久香综合精品久久伊人| 久久精品国产久精国产思思| 久久精品免费一区二区三区| 久久久久99精品成人片三人毛片| 亚洲美日韩Av中文字幕无码久久久妻妇 | 99久久国产亚洲高清观看2024| 日韩十八禁一区二区久久| 婷婷伊人久久大香线蕉AV | 色播久久人人爽人人爽人人片aV| 久久香综合精品久久伊人| 久久精品成人国产午夜| 中文成人无码精品久久久不卡 |