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

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

            用MapViewOfFile處理大文件-內存不足

            MapViewOfFile處理大文件時,如果文件過大,如400M,則無法一次性映射入內存,否則會出現1132錯誤,即內存不足。原因可能為操作系統無法找到連續的內存。因此需要通過分頁的方式,逐頁將文件內容映射到內存。
            相關資料:
            LPVOID MapViewOfFile(HANDLE hFileMappingObject,

              DWORD dwDesiredAccess,

              DWORD dwFileOffsetHigh,

              DWORD dwFileOffsetLow,

              DWORD dwNumberOfBytesToMap);

              MapViewOfFile()函數負責把文件數據映射到進程的地址空間,參數hFileMappingObject CreateFileMapping()返回的文件映像對象句柄。參數dwDesiredAccess則再次指定了對文件數據的訪問方式,而且同樣要與 CreateFileMapping()函數所設置的保護屬性相匹配。雖然這里一再對保護屬性進行重復設置看似多余,但卻可以使應用程序能更多的對數據的保護屬性實行有效控制。MapViewOfFile()函數允許全部或部分映射文件,在映射時,需要指定數據文件的偏移地址以及待映射的長度。其中,文件的偏移地址由DWORD型的參數dwFileOffsetHighdwFileOffsetLow組成的64位值來指定,而且必須是操作系統的分配粒度的整數倍,對于Windows操作系統,分配粒度固定為64KB。當然,也可以通過如下代碼來動態獲取當前操作系統的分配粒度:

              SYSTEM_INFO sinf;

              GetSystemInfo(&sinf);

              DWORD dwAllocationGranularity = sinf.dwAllocationGranularity;

              參數dwNumberOfBytesToMap指定了數據文件的映射長度,這里需要特別指出的是,對于Windows 9x操作系統,如果MapViewOfFile()無法找到足夠大的區域來存放整個文件映射對象,將返回空值(NULL);但是在Windows 2000下,MapViewOfFile()只需要為必要的視圖找到足夠大的一個區域即可,而無須考慮整個文件映射對象的大小。

            由此看出,分頁映射文件時,每頁的起始位置startpos,必須為64K的整數倍。

            HANDLE hFile=::CreateFile("c:\\111.dwf",GENERIC_READ,FILE_SHARE_READ | FILE_SHARE_WRITE,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_READONLY,NULL);

            ////////////////////////////////////////////////////////////////////
            // CreateFileMapping
            dwMaximumsize必須設置為0,否則MapViewOfFileoffset>0時,映射失敗
            HANDLE m_hCurFileMap = CreateFileMapping
                (    hFile,    NULL,    PAGE_READONLY,    0,     0,    NULL    );
            DWORD offset=64*1024;
            LPVOID m_pReadBuffer=MapViewOfFile(m_hCurFileMap,FILE_MAP_READ,
               (DWORD)0,
               (DWORD)(offset & 0xFFFFFFFF),
               offset
               );

             

            就個人使用情況而言,使用內存映射并不見得比使用流處理要快,前提是流操作的當的話

             

            如果文件沒有碎片,流是不慢的,但是如果磁盤碎片很多,你用流處理100M的文件要1分鐘,可能你處理200M的文件就要3分鐘。

             

            采用分頁機制吧。
            例如設定每次映射大小為50M,首先映射第一個50M,處理完后,映射第二個50M
            FileMapping
            本身支持offset的。

             

             

            posted on 2011-02-16 17:52 肥仔 閱讀(7322) 評論(0)  編輯 收藏 引用 所屬分類: Windows開發

            久久综合狠狠综合久久综合88 | 亚洲午夜久久久久久久久久| 欧美久久久久久| 亚洲AV乱码久久精品蜜桃| 日本精品久久久中文字幕| 一本大道久久东京热无码AV | 国色天香久久久久久久小说| 国产精品久久久久影院嫩草| 亚洲国产一成久久精品国产成人综合| 久久无码人妻一区二区三区| 国产成人精品久久一区二区三区av| 国产精品久久久久蜜芽| 久久国产精品国语对白| 97久久久久人妻精品专区| 亚洲国产美女精品久久久久∴| 久久久久九国产精品| 久久亚洲高清观看| 久久久一本精品99久久精品66| 欧美一区二区久久精品| 久久一区二区三区99| 99久久精品免费观看国产| 亚洲乱亚洲乱淫久久| 色偷偷888欧美精品久久久| 国产午夜精品理论片久久影视 | 亚洲精品高清久久| 久久精品视频网| 2021精品国产综合久久| WWW婷婷AV久久久影片| 91精品国产高清91久久久久久| 精品久久久久香蕉网| 国产91久久精品一区二区| 久久精品aⅴ无码中文字字幕不卡| 亚洲精品白浆高清久久久久久 | 狠狠久久综合伊人不卡| 国产2021久久精品| 久久人搡人人玩人妻精品首页| 日韩欧美亚洲综合久久影院Ds | 国产香蕉97碰碰久久人人| 久久本道综合久久伊人| 久久99这里只有精品国产| 老男人久久青草av高清|