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

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            轉自:http://blog.csdn.net/psusong/archive/2009/01/08/3737047.aspx

               MMX和SSE都是INTEL開發的基于SIMD(單指令多數據流)的技術。所謂單指令多數據流是指可以用一條指令可以完成多個數據的操作。雖然64位系統已經推出,但是我們大部分都是使用32位系統,所以如果要完成兩個128位的相加運算,用普通32位指令很明顯要執行4條相加指令,而基于64位的MMX指令只需要執行兩次即可完成,更強大的SSE能一次處理128位,故一次就可以完成操作,所以采用MMX及SSE優化能夠大幅度提升程序性能。
               MMX采用處理器的80位的浮點寄存器的低64位作為MMX寄存器,一共有8個,從mm0到mm7,因為是“借用”浮點寄存器的低64位所以每次在用完MMX指令后一定要用EMMS指令將寄存器清空,MMX主要是針對整數運算進行優化,一個64位的MMX寄存器可以同時存入8個8位或者4個16位的整數,估計一次性就可以完成8次8位運算或者4次16位運算,要注意的MMX指令不能直接對32位數進行2次運算,但可以把32位拆分成兩個16位再進行運算。MMX技術還有一個非常有用的特性是飽和運算,比如兩個8位數相加:128+129相加后很明顯超過了8位的最大值256,但是進行飽和運算相加的結果將是最大值256,飽和運算將運算結果控制在相應位數的范圍內。
               最近在調試開發一個多媒體相關的程序,發現一個非常奇怪的問題,某些操作之后會導致隨后的float數運算結果混亂,花了1個小時的時間才發現是因為自己在使用完MMX指令后忘記用emms指令將浮點寄存器復位!


             

            posted on 2009-11-10 19:11 會飛的兔子 閱讀(853) 評論(0)  編輯 收藏 引用 所屬分類: 系統API,底層技術
            久久精品无码免费不卡| 久久婷婷五月综合97色直播| 久久青青草原精品国产| 久久w5ww成w人免费| 久久激情亚洲精品无码?V| 免费一级欧美大片久久网| 久久久久久伊人高潮影院| 国产精品对白刺激久久久| 中文字幕成人精品久久不卡| 久久WWW免费人成—看片| 四虎国产精品成人免费久久| 久久丫精品国产亚洲av不卡| 久久人人爽人人爽人人片AV麻豆 | 久久亚洲国产成人影院| 77777亚洲午夜久久多喷| 久久精品www人人爽人人| 久久本道久久综合伊人| 亚洲AV日韩AV永久无码久久| 99精品久久久久久久婷婷| 久久午夜羞羞影院免费观看| 久久丝袜精品中文字幕| 久久精品一区二区国产| 久久精品亚洲AV久久久无码| 国产免费福利体检区久久| 久久精品国产亚洲av麻豆图片 | 久久久久波多野结衣高潮| 91久久福利国产成人精品| 亚洲精品白浆高清久久久久久| 精品久久国产一区二区三区香蕉| 日韩乱码人妻无码中文字幕久久| 亚洲&#228;v永久无码精品天堂久久 | 久久无码人妻一区二区三区| 久久青青草原精品国产软件| 久久精品国产亚洲7777| 99久久精品无码一区二区毛片| 久久人人爽人人爽人人片av高请| 亚洲精品无码久久久影院相关影片| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久无码人妻一区二区三区| 久久亚洲美女精品国产精品| 久久久久久夜精品精品免费啦|