• <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>
            隨筆 - 11  文章 - 0  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿

            隨筆分類(lèi)

            隨筆檔案

            相冊(cè)

            關(guān)注

            網(wǎng)站

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            CPU與GPU這兩個(gè)處理器不是同步運(yùn)行的,當(dāng)CPU要GPU畫(huà)第10個(gè)對(duì)象時(shí),GPU可能還在畫(huà)第一個(gè)對(duì)象。CPU與GPU不同步現(xiàn)象與是否使用Shader無(wú)關(guān),無(wú)論是否使用Shader,CPU與GPU都不會(huì)同步運(yùn)行。
            CPU調(diào)用Direct3D和OpenGL的繪圖函數(shù)來(lái)繪圖時(shí),這些指定不會(huì)被GPU馬上運(yùn)行,而是存放在某一塊內(nèi)存中,這快內(nèi)存稱(chēng)為Command Buffer。GPU會(huì)一直從Command Buffer中取出CPU所指派的工作。當(dāng)Command Buffer為空時(shí),GPU就會(huì)閑下來(lái)。當(dāng)Command Buffer被塞滿(mǎn)時(shí),CPU就不能再下新的命令,這個(gè)時(shí)候若CPU繼續(xù)下命令,CPU就會(huì)被暫停,知道GPU處理并清除掉一些Command Buffer中的命令后,CPU才能繼續(xù)運(yùn)行。
            如果CPU和GPU是同步運(yùn)行的,那就代表有很多時(shí)候需要把CPU暫停,等GPU畫(huà)完才能恢復(fù)CPU的運(yùn)行。例如,如果CPU調(diào)用DrawPrimitive畫(huà)一萬(wàn)個(gè)三角形,DrawPrimitive函數(shù)需要等GPU把這一萬(wàn)個(gè)三角形全部畫(huà)完才會(huì)return。這樣CPU在DrawPrimitive運(yùn)行結(jié)束前只是被暫停,沒(méi)做任何事,浪費(fèi)了硬件的資源,有效率的做法是CPU調(diào)用DrawPrimitive時(shí),DrawPrimitive函數(shù)只是把畫(huà)一萬(wàn)個(gè)三角形的指令放在Command Buffer中,指令放好后立即return,讓CPU做其他的事情。只要Command Buffer夠大、CPU新增指令和GPU繪圖的速度配合好,CPU和GPU就可以同時(shí)完成各自的工作。
            CPU和GPU的不同步現(xiàn)象對(duì)Shader的編寫(xiě)事實(shí)上沒(méi)有太大影響,不過(guò)要了解這個(gè)問(wèn)題。C++代碼在試圖改變顯示內(nèi)存中的貼圖和頂點(diǎn)數(shù)據(jù)時(shí),有可能這些數(shù)據(jù)正被GPU使用。這個(gè)時(shí)候強(qiáng)制更新的話(huà),會(huì)得到錯(cuò)誤的繪圖結(jié)果。如果要CPU暫停等到GPU更新完后更新數(shù)據(jù),會(huì)拖慢程序的運(yùn)行速度。有時(shí)我們會(huì)使用double buffer的方法,讓CPU和GPU不同時(shí)存取一塊內(nèi)存。CPU更新buffer1的時(shí)候讓GPU讀取buffer2,下一個(gè)畫(huà)面是CPU更新buffer2,GPU讀取buffer1。雖然這樣會(huì)讓畫(huà)面顯示的數(shù)據(jù)慢一步,但是在視覺(jué)上沒(méi)有太大的影響。通常游戲的幀數(shù)是30到60,畫(huà)面反映慢一步,等于只是慢了1/30 - 1/60秒,幾乎不會(huì)感覺(jué)到。
            ----摘自《3D繪圖程序設(shè)計(jì)》
            posted on 2010-02-26 17:27 郭小帥 閱讀(1386) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Shader
            久久精品国产亚洲av瑜伽| 精品亚洲综合久久中文字幕| 午夜精品久久久久9999高清| 久久综合鬼色88久久精品综合自在自线噜噜 | 久久精品a亚洲国产v高清不卡 | 国产精品美女久久久久网| 国产巨作麻豆欧美亚洲综合久久| 亚洲国产成人精品91久久久| 久久综合给久久狠狠97色| 国产精品一区二区久久精品无码 | 7777久久亚洲中文字幕| 久久se精品一区二区影院| 亚洲精品无码成人片久久| 精品乱码久久久久久夜夜嗨| 少妇内射兰兰久久| 天堂无码久久综合东京热| jizzjizz国产精品久久| 久久人人爽人人爽人人av东京热 | 久久精品国产第一区二区| 漂亮人妻被黑人久久精品| 日韩电影久久久被窝网| 国内精品久久久久影院免费| 久久精品久久久久观看99水蜜桃| 久久无码av三级| 国产精品青草久久久久婷婷| 色婷婷久久综合中文久久蜜桃av| 久久精品免费大片国产大片| 久久国产色AV免费观看| 亚洲AV日韩精品久久久久| 无夜精品久久久久久| 久久青青国产| 性做久久久久久久久老女人| 久久精品无码一区二区三区日韩| 亚洲欧美精品伊人久久| 国内精品人妻无码久久久影院| 亚洲国产另类久久久精品| 中文字幕人妻色偷偷久久| 中文字幕乱码久久午夜| 亚洲精品乱码久久久久久蜜桃图片 | 久久精品亚洲男人的天堂| 国产精品久久久天天影视香蕉|