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

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            程序I/O優(yōu)化

                   本文講述在編寫C程序代碼的常用優(yōu)化辦法,分為I/O篇,內(nèi)存篇,算法篇,MMX匯編篇。

            一.I/O

                   如果有文件讀寫的話,那么對文件的訪問將是影響程序運(yùn)行速度的一大因素。提高文件訪問速度的主要辦法有兩個:一是采用內(nèi)存映射文件,二是使用內(nèi)存緩沖。下面是一組測試數(shù)據(jù)(見《UNIX環(huán)境高級編程》3.9節(jié)),顯示了用18種不同的緩存長度,讀1 468 802字節(jié)文件所得到的結(jié)果。

            緩沖大小

            用戶CPU(秒)

            系統(tǒng)CPU(秒)

            時鐘時間(秒)

            循環(huán)次數(shù)(秒)

            1

            23.8

            397.9

            423.4

            1 468 802

            2

            12.3

            202.0

            215.2

            734 401

            4

            6.1

            100.6

            107.2

            367 201

            8

            3.0

            50.7

            54.0

            183 601

            16

            1.5

            25.3

            27.0

            91 801

            32

            0.7

            12.8

            13.7

            45 901

            64

            0.3

            6.6

            7.0

            22 951

            128

            0.2

            3.3

            3.6

            11 476

            256

            0.1

            1.8

            1.9

            5 738

            512

            0.0

            1.0

            1.1

            2 869

            1 024

            0.0

            0.6

            0.6

            1 435

            2 048

            0.0

            0.4

            0.4

            718

            4 096

            0.0

            0.4

            0.4

            359

            8 192

            0.0

            0.3

            0.3

            180

            16 384

            0.0

            0.3

            0.3

            90

            32 768

            0.0

            0.3

            0.3

            45

            65 536

            0.0

            0.3

            0.3

            23

            131 072

            0.0

            0.3

            0.3

            12

            可見,一般的當(dāng)內(nèi)存緩沖區(qū)大小為8192的時候,性能就已經(jīng)是最佳的了,這也就是為什么在H.263等圖像編碼程序中,緩沖區(qū)大小為8192的原因(有的時候也取2048大?。?。使用內(nèi)存緩沖區(qū)方法的好處主要是便于移植,占用內(nèi)存少,便于硬件實(shí)現(xiàn)等。下面是讀取文件的C偽碼:

                int Len;

            BYTE buffer[8192];

                ASSERT(buffer==NULL);

                If buffer is empty{

                    Len=read(File,buffer,8192);

                    If(len==0) No data and exit;

                }

                   

            但是如果內(nèi)存比較大的時候,采用內(nèi)存映射文件可以達(dá)到更佳性能,并且編程實(shí)現(xiàn)簡單。內(nèi)存映射的具體使用說明見msdn October 2001中的Platform SDK

            Documentation—Base Services—File Storage—File Mapping。下面是一點(diǎn)建議:

            內(nèi)存映射文件不能超過虛擬內(nèi)存的大小,最好也不要太大,如果內(nèi)存映射文件接近虛擬內(nèi)存大小的時候,反而會大大降低程序的速度(其實(shí)是因為虛擬內(nèi)存不足導(dǎo)致系統(tǒng)運(yùn)行效率降低),這個時候,可以考慮分塊映射,但是我覺得如果這樣,還不如直接使用內(nèi)存緩沖來得直接一些。

            可以將兩種方法統(tǒng)一使用,如我在編大圖像文件數(shù)據(jù)處理的時候(因為是Unix工作站,內(nèi)存很大GB單位)使用了內(nèi)存映射文件,但是為了最佳性能,也使用了一行圖像緩存,這樣在讀取文件中數(shù)據(jù)的時候,就保證了僅僅是順序讀寫(內(nèi)存映射文件中,對順序讀寫有專門的優(yōu)化)。

            在寫文件的時候使用內(nèi)存映射文件要有一點(diǎn)小技巧:應(yīng)該先創(chuàng)建足夠大的文件,然后將這個文件映射,在處理完這個文件的時候,用函數(shù)SetFilePointerSetEndOfFile來對文件進(jìn)行截尾

            對內(nèi)存映射文件進(jìn)行操作與對內(nèi)存進(jìn)行操作類似(使用起來就象數(shù)組一樣),那么如果有大塊數(shù)據(jù)讀寫的時候,切記使用memcpy()函數(shù)(或者CopyMemory()函數(shù))

             

                總之,如果要使用內(nèi)存映射文件,必須:1.處理的文件比較的小,2.處理的文件很大,但是運(yùn)行環(huán)境內(nèi)存也很大,并且一般在運(yùn)行該程序的時候不運(yùn)行其他消耗內(nèi)存大的程序,同時用戶對速度有特別的要求,而且對內(nèi)存占用沒有什么要求。如果以上兩個條件不滿足的時候,建議使用內(nèi)存緩沖區(qū)的辦法。

             

            posted on 2009-03-12 12:31 肥仔 閱讀(802) 評論(1)  編輯 收藏 引用 所屬分類: Windows開發(fā)

            評論

            # re: 程序I/O優(yōu)化[未登錄]  回復(fù)  更多評論   

            我覺得第一點(diǎn)的8K大小,最優(yōu)化值是系統(tǒng)內(nèi)存管理的頁和內(nèi)存分配粒度、文件系統(tǒng)的簇大小等等這些的整數(shù)倍吧?
            2010-04-27 10:38 | riverqh
            色婷婷噜噜久久国产精品12p| 国产一区二区精品久久凹凸| 免费久久人人爽人人爽av| 久久人人爽人人爽人人片AV高清 | 国产精品久久久久jk制服| 久久亚洲国产中v天仙www| 亚洲精品无码久久久久AV麻豆| 伊人久久综合无码成人网| 91久久香蕉国产熟女线看| 亚洲七七久久精品中文国产| 久久亚洲精品国产精品| 日本精品久久久久久久久免费| 国产∨亚洲V天堂无码久久久| 人妻丰满?V无码久久不卡| 狠狠色丁香久久综合五月| 一97日本道伊人久久综合影院| 99久久免费国产精精品| 久久精品一本到99热免费| 成人国内精品久久久久影院VR| 伊人久久大香线蕉av不卡| 久久99精品久久久久久齐齐 | 人妻少妇久久中文字幕一区二区| 久久精品国产99国产精品澳门| 亚洲精品无码专区久久久| 久久受www免费人成_看片中文| 99久久精品免费看国产免费| 国产精品毛片久久久久久久| 伊人久久大香线焦AV综合影院| 欧美激情精品久久久久久久| 亚洲乱亚洲乱淫久久| 色偷偷888欧美精品久久久| 久久婷婷五月综合97色| 亚洲国产欧美国产综合久久| 亚洲а∨天堂久久精品9966| 久久www免费人成看国产片| 91精品免费久久久久久久久| 色综合久久中文色婷婷| 91精品久久久久久无码| 国内精品久久久久久久亚洲| 国产99久久久国产精品~~牛| 久久久精品免费国产四虎|