• <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>
            隨筆 - 5, 文章 - 0, 評論 - 13, 引用 - 0
            數據加載中……

            vc編譯期的常量除法優化

            在vc release模式下調試時,經常可以看到下面形式的匯編代碼:
            00FB1202  mov         ecx,dword ptr ds:[00FB543Ch] 
            00FB1208  sub         ecx,dword ptr ds:[00FB5438h] 
            00FB120E  mov         eax,66666667h 
            00FB1213  imul        ecx  
            00FB1215  sar         edx,
            5 
            00FB1218  mov         ecx,edx 
            00FB121A  shr         ecx,1Fh 
            00FB121D  add         ecx,edx 
            其實這是當被除數是常量時除法的編譯器優化。x/50h
            優化方法是把除法轉換成乘以被除數然后右移.
            x/y =>  x*(1 /y) =>  x* ((1<<37) /((1<<37)* y) ) =>x * ((1<<37)/ y)>>37
            為了取整效果,最終結果將會是
            x/y = x * ((1<<37 +y-1 )/ y)>>37
            由于y 是常量,在編譯期,編譯器就可以計算出((1<<37 +y-1 )/ y)的值。
            那么實際計算時,編譯期就可以把 x/y 轉換成 x *M >> 37, M =
            ((1<<37 +y-1 )/ y)
            除以0x50 M = (1<<37 + 0x4F)/0x50 = 0x
            66666667
            那么x / 0x50相當于 (x*
            0x66666667)>>37

            posted on 2009-02-23 00:16 clane 閱讀(1429) 評論(1)  編輯 收藏 引用 所屬分類: C++

            評論

            # re: vc編譯期的常量除法優化  回復  更多評論   

            除以常數轉換為乘以常數.
            2009-09-23 15:00 | 金慶
            久久精品视频网| 久久精品国产黑森林| 一本一本久久A久久综合精品| 浪潮AV色综合久久天堂| 久久人妻少妇嫩草AV蜜桃| 国产精品一久久香蕉国产线看观看| 青青青国产成人久久111网站| 久久久久久久波多野结衣高潮| segui久久国产精品| 国产精品久久久久久久久免费| 国产成人无码精品久久久性色| 精品久久久久香蕉网| 久久综合九色欧美综合狠狠| 色8久久人人97超碰香蕉987| 国产精品gz久久久| 国产∨亚洲V天堂无码久久久 | 久久久久久免费视频| 人妻无码久久精品| 久久亚洲中文字幕精品一区四| 国产精品99久久精品| 色妞色综合久久夜夜| 亚洲人成精品久久久久| 亚洲国产日韩欧美综合久久| 合区精品久久久中文字幕一区| 久久er热视频在这里精品| 亚洲精品国产字幕久久不卡| 久久久久亚洲av成人无码电影| 久久久久中文字幕| 99热成人精品热久久669| 久久综合亚洲欧美成人| 日韩人妻无码精品久久久不卡| 亚洲AV伊人久久青青草原| 久久久久国产| 久久国产影院| 无码8090精品久久一区| 久久人人爽人爽人人爽av| 色综合久久中文字幕综合网| 亚洲欧美一级久久精品| 国产成人精品综合久久久| 久久婷婷五月综合97色| 久久精品男人影院|