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

關于for循環的執行效率問題

先提出這樣一個問題,是我昨天去一家公司面試時遇到的問題,
模塊一:
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個例子說明模塊一比模塊二執行效率高,同樣舉出3個例子證明模塊二比模塊一執行效率高。
頭一次遇到這種問題,很棘手,我當時的思路是從cpu執行效率、內存使用效率這兩個方面來考慮,列舉了一些可能的情況,應付了過去。
回來仔細想了一下,查了一些相關的帖子好像都有提過,但都不是很全面,先把問題拋在這個地方等搞清楚了在寫。

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









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

導航

<2011年12月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

統計

常用鏈接

留言簿(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>
            亚洲电影免费观看高清完整版在线 | 亚洲国产欧美在线人成| 亚洲毛片在线观看| 一本色道久久综合亚洲精品小说| 欧美大片在线观看一区二区| 亚洲人成高清| 国产精品99久久久久久人| 欧美日韩亚洲激情| 亚洲免费在线观看| 麻豆免费精品视频| 亚洲精品美女91| 国产精品高清在线观看| 新狼窝色av性久久久久久| 久久综合一区二区三区| 日韩一区二区免费看| 国产精品免费观看在线| 性欧美在线看片a免费观看| 欧美 日韩 国产在线| 中文在线资源观看视频网站免费不卡| 国产精品v欧美精品v日韩| 午夜精品久久久久久久久久久久 | 91久久久久| 国产精品毛片大码女人| 亚洲一区二区黄| 国产精品综合久久久| 狼人天天伊人久久| 亚洲视频www| 亚洲高清精品中出| 久久成人av少妇免费| 亚洲最新色图| 在线观看成人网| 欧美色图麻豆| 免费h精品视频在线播放| 欧美亚洲色图校园春色| 亚洲伦理在线观看| 老鸭窝亚洲一区二区三区| 亚洲一区二区三区四区视频| 在线国产亚洲欧美| 国产日韩在线看| 欧美日韩国产综合网| 免费观看成人| 久久久精品动漫| 性欧美精品高清| 亚洲欧美日韩高清| 一区二区毛片| 99riav1国产精品视频| 欧美激情一区二区三区在线视频| 久久久久久久久久久一区| 午夜精品影院| 亚洲视频图片小说| 亚洲精品一区中文| 最新国产成人av网站网址麻豆| 国产欧美日韩一区二区三区在线| 欧美日韩在线高清| 欧美日韩精品免费观看视一区二区| 裸体女人亚洲精品一区| 久久躁狠狠躁夜夜爽| 久久久中精品2020中文| 午夜视频在线观看一区二区三区| 亚洲一区二区三区在线观看视频| 99精品视频免费| 亚洲福利电影| 欧美激情导航| 久久免费精品日本久久中文字幕| 麻豆精品视频在线观看| 欧美大片在线看| 亚洲国产欧美日韩精品| 日韩午夜中文字幕| 亚洲视频中文| 亚洲图片欧洲图片av| 亚洲一区视频在线观看视频| 亚洲欧美日韩国产一区二区三区| 亚洲欧美综合另类中字| 久久精品91久久久久久再现| 欧美中文在线观看| 久热re这里精品视频在线6| 久久在线免费| 亚洲精品久久久久久久久久久久 | 老牛影视一区二区三区| 欧美主播一区二区三区| 麻豆成人91精品二区三区| 亚洲高清免费视频| 亚洲视屏一区| 国产精品国产三级欧美二区| 国产精品亚洲综合色区韩国| 黄色精品一区| 一区二区欧美精品| 性久久久久久| 久久久久久综合| 欧美激情中文字幕在线| 亚洲一区二区三区中文字幕| 久久精品亚洲| 欧美国产一区二区| 国产欧美日韩视频在线观看 | 欧美成人有码| 欧美日在线观看| 国产一区视频在线观看免费| 最新日韩在线| 性欧美大战久久久久久久免费观看| 香蕉久久久久久久av网站| 欧美mv日韩mv国产网站| 亚洲午夜电影| 免费观看久久久4p| 韩国欧美一区| 中文在线不卡视频| 亚洲国产经典视频| 欧美在现视频| 国产精品video| 日韩天堂在线观看| 欧美h视频在线| 久久精品国产久精国产爱| 欧美性天天影院| 日韩午夜在线视频| 欧美电影电视剧在线观看| 翔田千里一区二区| 国产免费亚洲高清| 亚洲欧美日韩国产综合在线 | 久久av二区| 国产精品久久久久国产精品日日| 亚洲日韩欧美一区二区在线| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲一级黄色av| 欧美日产在线观看| 亚洲精品三级| 亚洲大片在线| 蜜桃av一区二区| 狠狠操狠狠色综合网| 久久精品二区三区| 欧美在线三区| 99热这里只有精品8| 欧美日韩国产成人在线观看| 亚洲理伦电影| 亚洲激情在线视频| 欧美精品黄色| 亚洲视频一区二区| 一区二区免费看| 欧美激情综合五月色丁香| 亚洲电影免费| 亚洲风情亚aⅴ在线发布| 欧美二区乱c少妇| 亚洲人午夜精品免费| 亚洲激情在线观看视频免费| 欧美丰满少妇xxxbbb| 99re热这里只有精品免费视频| 亚洲国产色一区| 欧美日本二区| 香蕉久久夜色精品国产使用方法| 亚洲尤物视频网| 国产亚洲精品aa| 欧美aa国产视频| 欧美激情影院| 欧美一级精品大片| 久久精品欧美| 亚洲精品乱码久久久久久黑人 | 欧美+日本+国产+在线a∨观看| 久久午夜av| 一区二区不卡在线视频 午夜欧美不卡在 | 永久免费视频成人| 亚洲高清不卡在线观看| 国产精品大片wwwwww| 欧美一区二区三区免费大片| 久久激情视频久久| 亚洲激情网站免费观看| 一本色道久久综合| 国产一区二区主播在线| 欧美电影在线| 欧美gay视频激情| 亚洲人成亚洲人成在线观看图片| 欧美福利专区| 欧美日韩日日骚| 久久久久青草大香线综合精品| 老司机精品视频一区二区三区| 在线视频日韩| 欧美在线综合视频| 亚洲午夜激情免费视频| 久久久伊人欧美| 欧美一区二区黄色| 欧美伦理在线观看| 久久综合久色欧美综合狠狠| 欧美日韩另类综合| 欧美高清视频免费观看| 亚洲综合色视频| 亚洲日韩成人| 欧美中文字幕视频| 亚洲欧美日韩国产精品| 欧美国产专区| 久久噜噜噜精品国产亚洲综合| 欧美日本一区| 欧美成人资源网| 国产尤物精品| 亚洲一区二区三区高清| 亚洲精品网站在线播放gif| 欧美一区亚洲二区| 先锋影音一区二区三区| 欧美激情一区二区三区全黄| 久久久久成人精品免费播放动漫| 欧美视频久久| 亚洲免费av网站| 亚洲激情欧美| 久久人91精品久久久久久不卡 |