青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

關(guān)于for循環(huán)的執(zhí)行效率問題

先提出這樣一個問題,是我昨天去一家公司面試時遇到的問題,
模塊一:
1  forint i= 0;i<N; i++)
2  {
3      A;
4      B;
5      C;
6  }
7 
模塊二:
 1  forint i= 0;i<N; i++)
 2  {
 3      A;
 4  }
 5  forint i= 0;i<N; i++)
 6  {
 7      B;
 8  }
 9 
10  forint i= 0;i<N; i++)
11  {
12      C;
13  }
舉出3個例子說明模塊一比模塊二執(zhí)行效率高,同樣舉出3個例子證明模塊二比模塊一執(zhí)行效率高。
頭一次遇到這種問題,很棘手,我當(dāng)時的思路是從cpu執(zhí)行效率、內(nèi)存使用效率這兩個方面來考慮,列舉了一些可能的情況,應(yīng)付了過去。
回來仔細(xì)想了一下,查了一些相關(guān)的帖子好像都有提過,但都不是很全面,先把問題拋在這個地方等搞清楚了在寫。

我以前遇到的問題大概都是這種類型的:
 1 for(int i = 0;i<100;i++)
 2 {
 3    for(int j = 0;j<10000;j++)
 4    {
 5       //balabala
 6    }
 7 }
 8 和
 9 for(int i = 0;i<10000;i++)
10 {
11    for(int j = 0;j<100;j++)
12    {
13       //balabala
14    }
15 }
這兩個程序那個執(zhí)行效率高,如果是以前我會毫不猶豫的說是第一個效率高,這是由于cpu切換的次數(shù)比較多導(dǎo)致性能下降,知道這句話不理解什么原理。我比較贊同下面的說法,
1. 最長循環(huán)放到內(nèi)部可以提高I cache的效率,降低因為循環(huán)跳轉(zhuǎn)造成cache的miss以及流水線flush造成的延時
2. 多次相同循環(huán)后也能提高跳轉(zhuǎn)預(yù)測的成功率,提高流水線效率
3. 編譯器會自動展開循環(huán)提高效率, 這個不一定是必然有效的
但不是絕對正確的,比如: 1 int x[1000][100];
 2 for(i=0;i<1000;i++)
 3   for(j=0;j<100;j++)
 4 {
 5   //access x[i][j]
 6 }
 7 
 8 int x[1000][100];
 9 for(j=0;j<100;j++)
10   for(i=0;i=1000;i++)
11 {
12   //access x[i][j]
13 }
14 
這時候第一個的效率就比第二個的高,原因嘛和硬件也有一些關(guān)系,CPU對于內(nèi)存的訪問都是通過數(shù)據(jù)緩存(cache)來進(jìn)行的。
比如一個通用CPU,一級緩存(L1-Cache)的大小為16K,而其組織結(jié)構(gòu)為每32個字節(jié)一組(cache line size=32byte),
也就是每次從二級緩存或內(nèi)存取數(shù)據(jù)到一級緩存,都是一次性取32個字節(jié)。
對于上面的第一段代碼,每次取數(shù)據(jù)到一級緩存,都有連續(xù)8次內(nèi)存訪問可以共享一條緩存。
而對于第二段代碼,每次取數(shù)據(jù)到一級緩存后,訪問一次后,基本上就沒有機(jī)會被再次使用了;
上面這兩段代碼的區(qū)別在于第一段代碼,每次內(nèi)存訪問后,地址值需要加常數(shù)4,而第二段代碼,每次訪問后,地址值加400。
如果沒有對于緩存訪問的區(qū)別,那么這時我們的確可以將長的循環(huán)放在里層,短的放在外層。但是而其主要原因不是一般人所想象的指令數(shù)目的區(qū)別的問題,
而主要由于分支預(yù)測錯誤會引起的流水線中斷從而導(dǎo)致性能的降低。
     最后一個問題,有人說while比for循環(huán)效率高,不知道這個假設(shè)是否正確,先立在這搞清楚再補(bǔ)充。









posted on 2011-12-07 19:57 sheng 閱讀(3251) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導(dǎo)航

<2012年8月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

統(tǒng)計

常用鏈接

留言簿(1)

隨筆檔案

收藏夾

同行

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩精品在线| 欧美www视频| 欧美涩涩网站| 亚洲青色在线| 欧美大色视频| 久久免费少妇高潮久久精品99| 国产精品99免费看| 一区二区三区免费看| 亚洲国产乱码最新视频| 久热综合在线亚洲精品| 亚洲黑丝在线| 亚洲激情不卡| 欧美女同在线视频| 亚洲图片自拍偷拍| 亚洲视频图片小说| 国产精品日韩欧美一区二区| 亚洲免费在线| 欧美一二三区精品| 一区二区三区在线视频播放| 猛干欧美女孩| 久久亚洲欧洲| 日韩天堂av| 一区二区三区日韩欧美| 国产精品免费区二区三区观看| 亚洲欧美美女| 香蕉乱码成人久久天堂爱免费| 韩国成人理伦片免费播放| 亚洲图片自拍偷拍| 99精品视频免费全部在线| 国产精品hd| 欧美淫片网站| 久久久免费精品视频| 韩国精品主播一区二区在线观看| 久久亚洲私人国产精品va媚药| 美女在线一区二区| 一区二区三区免费看| 羞羞漫画18久久大片| 在线不卡亚洲| 一区二区欧美日韩视频| 国产欧美日韩三级| 欧美高清视频一区二区| 欧美精品在线网站| 性欧美大战久久久久久久久| 久久久亚洲精品一区二区三区 | 亚洲人成在线观看一区二区| 欧美日韩在线一二三| 另类综合日韩欧美亚洲| 欧美日韩国产在线一区| 99精品热视频| 久久精品理论片| 亚洲一区二区日本| 久久乐国产精品| 午夜精品三级视频福利| 猛男gaygay欧美视频| 欧美在线综合视频| 欧美日韩精品免费观看视频完整| 久久精品日韩一区二区三区| 欧美三级在线播放| 欧美福利视频在线| 国产欧美一区二区三区在线看蜜臀| 欧美激情一区二区三区全黄| 国产日韩久久| 美女福利精品视频| 欧美激情亚洲自拍| 久久亚洲精选| 国产精品亚洲激情| 亚洲免费电影在线观看| 最新成人在线| 久久久久久午夜| 久久国产精品久久精品国产| 欧美日韩日日夜夜| 亚洲精美视频| 亚洲黄一区二区| 久久久久久久国产| 久久久久国色av免费看影院| 国产精品国产三级欧美二区| 亚洲美女福利视频网站| 亚洲精品久久久一区二区三区| 久久免费视频在线| 久久国产夜色精品鲁鲁99| 欧美午夜片欧美片在线观看| 亚洲麻豆一区| 亚洲精品欧美日韩专区| 久久久精品日韩| 久久久久在线| 韩日在线一区| 久久国产精品99国产| 久久久999精品| 国产婷婷一区二区| 欧美一级艳片视频免费观看| 久久精品国产第一区二区三区最新章节| 国产精品美女| 欧美一区二区三区视频在线观看 | 久久狠狠婷婷| 媚黑女一区二区| 亚洲成人原创| 欧美电影电视剧在线观看| 亚洲国产精品一区制服丝袜| 日韩亚洲不卡在线| 国产精品久久久久77777| 亚洲永久网站| 久久久五月婷婷| 伊人久久大香线蕉av超碰演员| 久久字幕精品一区| 亚洲另类春色国产| 亚洲欧美日韩一区二区在线| 国产深夜精品| 久久午夜国产精品| 亚洲国产精品成人| 中文一区二区在线观看| 国产视频观看一区| 免费影视亚洲| 在线视频日韩精品| 久久女同互慰一区二区三区| 亚洲人体1000| 国产精品亚洲视频| 美女精品国产| 亚洲午夜精品网| 免费高清在线视频一区·| 日韩视频免费| 国产欧美激情| 农夫在线精品视频免费观看| 一区二区日韩| 免费h精品视频在线播放| 亚洲性视频网址| 国产一区二区三区的电影 | 亚洲精品国产拍免费91在线| 欧美在线观看你懂的| 亚洲日本乱码在线观看| 国产精品亚洲精品| 欧美福利视频网站| 欧美在线首页| 亚洲免费小视频| 亚洲欧洲视频| 欧美不卡一区| 欧美一区二区三区四区在线| 亚洲精品久久久久久一区二区| 国产乱肥老妇国产一区二| 欧美精品一区二区在线播放| 久久国产精品久久久久久电车| 99这里只有精品| 欧美电影免费观看高清| 性欧美1819性猛交| 日韩视频不卡中文| 在线观看中文字幕亚洲| 国产一区二区三区观看| 国产精品久久久久久久久免费| 农村妇女精品| 久久免费99精品久久久久久| 香港久久久电影| 在线视频亚洲一区| 亚洲精品视频一区二区三区| 老牛国产精品一区的观看方式| 欧美一区二区视频97| 亚洲一二三区在线观看| 一本色道久久综合亚洲精品不 | 久久青草欧美一区二区三区| 香蕉成人伊视频在线观看| 一区二区三区四区五区精品视频| 亚洲欧洲日本在线| 亚洲精品久久久久久久久久久久 | 亚洲乱码国产乱码精品精天堂| 激情五月***国产精品| 国产一区二区高清| 国产最新精品精品你懂的| 国产欧美日本| 国产亚洲精品v| 国产日韩在线视频| 欧美日韩亚洲国产精品| 欧美激情网友自拍| 免费观看成人鲁鲁鲁鲁鲁视频| 久久国产精品毛片| 久久久美女艺术照精彩视频福利播放| 久久国产精品亚洲va麻豆| 久久久999国产| 蜜臀99久久精品久久久久久软件| 免费一级欧美片在线观看| 欧美激情成人在线视频| 欧美日韩久久不卡| 国产精品久久久久久久久搜平片| 国产精品久久久久久久久久ktv| 国产精品视频| 狠狠色综合色区| 亚洲精品久久久蜜桃| 在线一区免费观看| 欧美一区二区三区四区在线 | 国产亚洲欧美色| 在线欧美一区| 日韩性生活视频| 久久久国产精彩视频美女艺术照福利 | 欧美日韩xxxxx| 国产午夜精品久久久久久久| 亚洲久久一区| 久久免费一区| 亚洲一区欧美激情| 欧美激情亚洲自拍| 在线观看免费视频综合| 小黄鸭精品密入口导航| 亚洲人永久免费| 久久亚洲一区|