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

            CreateFileMapping 函數

            內存映射API函數CreateFileMapping創建一個有名的共享內存:
            HANDLE CreateFileMapping(
            HANDLE hFile,                                                                        // 映射文件的句柄,
                                                                                                               //設為0xFFFFFFFF以創建一個進程間共享的對象
            LPSECURITY_ATTRIBUTES lpFileMappingAttributes,   // 安全屬性
            DWORD flProtect,                                                                   // 保護方式
            DWORD dwMaximumSizeHigh,                                           //對象的大小
            DWORD dwMaximumSizeLow,
            LPCTSTR lpName                                                                 // 必須為映射文件命名
            );

            與虛擬內存類似,保護方式可以是PAGE_READONLY或是PAGE_READWRITE。如果多進程都對同一共享內存進行寫訪問,則必須保持相互間同步。映射文件還可以指定PAGE_WRITECOPY標志,可以保證其原始數據不會遭到破壞,同時允許其他進程在必要時自由的操作數據的拷貝。

            在創建文件映射對象后使用可以調用MapViewOfFile函數映射到本進程的地址空間內。

            下面說明創建一個名為MySharedMem的長度為4096字節的有名映射文件:
            HANDLE hMySharedMapFile=CreateFileMapping((HANDLE)0xFFFFFFFF),
            NULL,PAGE_READWRITE,0,0x1000,"MySharedMem");
            并映射緩存區視圖:
            LPSTR pszMySharedMapView=(LPSTR)MapViewOfFile(hMySharedMapFile,
            FILE_MAP_READ|FILE_MAP_WRITE,0,0,0);

            其他進程訪問共享對象,需要獲得對象名并調用OpenFileMapping函數。
            HANDLE hMySharedMapFile=OpenFileMapping(FILE_MAP_WRITE,
            FALSE,"MySharedMem");

            一旦其他進程獲得映射對象的句柄,可以象創建進程那樣調用MapViewOfFile函數來映射對象視圖。用戶可以使用該對象視圖來進行數據讀寫操作,以達到數據通訊的目的。

            當用戶進程結束使用共享內存后,調用UnmapViewOfFile函數以取消其地址空間內的視圖:
            if (!UnmapViewOfFile(pszMySharedMapView))
            {

                     AfxMessageBox("could not unmap view of file");

             }

            //=================================================================================
            //                  CreateFileMapping的MSDN翻譯和使用心得
            //=================================================================================
            測試創建和打開文件映射的時候老是得到"句柄無效"的錯誤, 仔細看了MSDN以后才發覺是函數認識不透, 這里把相關的解釋翻譯出來

            HANDLE CreateFileMapping(
              HANDLE hFile,                       //物理文件句柄
              LPSECURITY_ATTRIBUTES lpAttributes, //安全設置
              DWORD flProtect,                    //保護設置
              DWORD dwMaximumSizeHigh,            //高位文件大小
              DWORD dwMaximumSizeLow,             //低位文件大小
              LPCTSTR lpName                      //共享內存名稱
            );

            1) 物理文件句柄
               任何可以獲得的物理文件句柄, 如果你需要創建一個物理文件無關的內存映射也無妨, 將它設置成為 0xFFFFFFFF(INVALID_HANDLE_VALUE)就可以了.

               如果需要和物理文件關聯, 要確保你的物理文件創建的時候的訪問模式和"保護設置"匹配, 比如: 物理文件只讀, 內存映射需要讀寫就會發生錯誤. 推薦你的物理文件使用獨占方式創建.

               如果使用 INVALID_HANDLE_VALUE, 也需要設置需要申請的內存空間的大小, 無論物理文件句柄參數是否有效, 這樣 CreateFileMapping 就可以創建一個和物理文件大小無關的內存空間給你, 甚至超過實際文件大小, 如果你的物理文件有效, 而大小參數為0, 則返回給你的是一個和物理文件大小一樣的內存空間地址范圍.  返回給你的文件映射地址空間是可以通過復制, 集成或者命名得到, 初始內容為0.

            2) 保護設置
               就是安全設置, 不過一般設置NULL就可以了, 使用默認的安全配置. 在win2k下如果需要進行限制, 這是針對那些將內存文件映射共享給整個網絡上面的應用進程使用是, 可以考慮進行限制.

            3) 高位文件大小
               弟兄們, 我想目前我們的機器都是32位的東東, 不可能得到超過32位進程所能尋址的私有32位地址空間, 一般還是設置0吧, 我沒有也不想嘗試將它設置超過0的情況.
            4) 低位文件大小
               這個還是可以進行設置的, 不過為了讓其他共享用戶知道你申請的文件映射的相關信息, 我使用的時候是在獲得的地址空間頭部添加一個結構化描述信息, 記錄內存映射的大小, 名稱等, 這樣實際申請的空間就比輸入的增加了一個頭信息結構大小了, 我認為這樣類似BSTR的方式應該是比較合理的.

            5) 共享內存名稱
               這個就是我今天測試的時候碰壁的禍根, 因為為了對于內存進行互斥訪問, 我設置了一個互斥句柄, 而名稱我選擇和命名共享內存同名, 之下就是因為他們使用共同的namespace導致了錯誤, 呵呵.

            7) 調用CreateFileMapping的時候GetLastError的對應錯誤
               ERROR_FILE_INVALID     如果企圖創建一個零長度的文件映射, 應有此報
               ERROR_INVALID_HANDLE   如果發現你的命名內存空間和現有的內存映射, 互斥量, 信號量, 臨界區同名就麻煩了
               ERROR_ALREADY_EXISTS   表示內存空間命名已經存在

            8) 相關服務或者平臺的命名保留
               Terminal Services:
               命名可以包含 "Global" 或者 "Local" 前綴在全局或者會話名空間初級文件映射. 其他部分可以包含任何除了()以外的字符, 可以參考 Kernel Object Name Spaces.

               Windows 2000 or later:
               如果 Terminal Services 沒有運行 "Global" 和 "Local" 前綴的特殊含義就被忽略了

            posted on 2008-09-11 09:39 wrh 閱讀(1619) 評論(0)  編輯 收藏 引用

            導航

            <2010年12月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            統計

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            狠狠色丁香久久婷婷综合_中| 亚洲国产精品久久电影欧美| 93精91精品国产综合久久香蕉| 91久久国产视频| 国内精品久久久久久久coent| 亚洲精品无码久久久久| 国产高潮国产高潮久久久| 日韩欧美亚洲国产精品字幕久久久| 久久99精品国产麻豆宅宅| 四虎亚洲国产成人久久精品| 久久久精品久久久久影院| 久久中文字幕人妻熟av女| 中文字幕人妻色偷偷久久 | 久久影院综合精品| 最新久久免费视频| 久久精品亚洲乱码伦伦中文| 久久国产精品成人片免费| 久久成人18免费网站| 久久精品国产免费| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 99久久婷婷国产综合精品草原| 久久久久久久久久久精品尤物| 中文字幕成人精品久久不卡 | 久久99精品国产麻豆不卡| 久久精品国产影库免费看| 国产高潮国产高潮久久久91 | 狠狠色丁香久久婷婷综合五月| 久久亚洲AV无码精品色午夜麻豆 | 无遮挡粉嫩小泬久久久久久久| 国产精品久久久久久久久久影院| 亚洲精品tv久久久久| 色欲综合久久躁天天躁蜜桃| 国产精品久久波多野结衣| 久久精品国产亚洲欧美| 久久久久18| 久久99精品国产99久久| 久久亚洲天堂| 久久久av波多野一区二区| 国产精品狼人久久久久影院| 国产精品岛国久久久久| 性做久久久久久久久久久|