• <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>
            posts - 14, comments - 1, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            1.問題闡述

            傳統上都是用fread()、fwrite()之類的函數來存取文件,而文件映射把部分文件或全部文件映射在process的內存空間中,因此可以像存取內存一樣存取文件。

            2.實現技巧

            下面我們介紹創建文件映射的方法。在介紹CreateFileMapping()函數之前,必須先創建CreateFile()函數和OpenFile()函數打開映射到內存空間的文件,取得文件的句柄。

             CreateFileMapping()的函數聲明:
            HANDLE CreateFileMapping(
            HANDLE hFile,                            //文件的句柄
            LPSECURITY_ATTRIBUTES lpAttributes,  //與安全有關的設置
            DWORD flProtect,                         //用來決定與view有關的屬性
            DWORD dwMaximumSizeHigh,              //設置映射文件的尺寸
            DWORD dwMaximumSizeLow,
            LPCTSTR lpName                          //文件映射對象的名稱
            );
            MapViewOfFile()函數的聲明:
            LPVOID MapViewOfFile(
            HANDLE hFileMappingObject,        //文件映射的句柄
            DWORD dwDesiredAccess,           //此view的屬性
            DWORD dwFileOffsetHigh,           //view文件的起點
            DWORD dwFileOffsetLow,      
            SIZE_T dwNumberOfBytesToMap      //映射區的大小
            );
            3.實例代碼
            //發送數據
            void CTestDlg::OnBnClickedBtnsendinfo()
            {
            UpdateData(TRUE);
            //創建文件映像對象
            HANDLE hMapping;  
            LPSTR StrData;  
            hMapping=CreateFileMapping((HANDLE)0xFFFFFFFF,NULL,PAGE_READWRITE,0,
            0x100,"COMMUNICATION");  
            if(hMapping==NULL)  
            {  
            MessageBox("創建文件映像對象","信息提示",MB_OK);
            return;
            }
            //將文件映射到一個進程的地址空間上
            StrData=(LPSTR)MapViewOfFile(hMapping,FILE_MAP_ALL_ACCESS,0,0,0);  
            if(StrData==NULL)  
            {  
            AfxMessageBox("MapViewOfFile() failed.");
            MessageBox("文件映射失敗","信息提示",MB_OK);
            return;
            }
            //向映射內存寫數據
            sprintf(StrData,m_StrSendData);    
            //釋放映像內存
            UnmapViewOfFile(StrData);  
            }
            //接收數據
            void CTestDlg::OnBnClickedBtnreceiveinfo()
            {
            //創建文件映像對象
            HANDLE hMapping;  
            LPSTR StrData;  
            hMapping=CreateFileMapping((HANDLE)0xFFFFFFFF,NULL,PAGE_READWRITE,0,
            0x100,"COMMUNICATION");  
            if(hMapping==NULL)  
            {  
            MessageBox("創建文件映像對象","信息提示",MB_OK);
            return;
            }
            //將文件映射到一個進程的地址空間上
            StrData=(LPSTR)MapViewOfFile(hMapping,FILE_MAP_ALL_ACCESS,0,0,0);  
            if(StrData==NULL)  
            {  
            AfxMessageBox("MapViewOfFile() failed.");
            MessageBox("文件映射失敗","信息提示",MB_OK);
            return;
            }
            //獲取映像內存的數據量
            m_StrReceiveData.Format("%s",StrData);
            //釋放映像內存
            UnmapViewOfFile(StrData);  
            UpdateData(FALSE);
            }

            4.小結

            由于各個process之間是獨立的,因此彼此之間無法存取對方的內存空間,這雖然是安全的保護機制,但是如果要兩個process之間進行數據交換,那就又有問題了。不過win3又另外提供了一系列的進程通信的機制,幫助process與另外一個process交換數據。

            国产亚洲欧美精品久久久| 久久精品中文字幕一区| 精品乱码久久久久久久| 久久精品亚洲一区二区三区浴池| 亚洲中文字幕无码久久综合网 | 久久亚洲私人国产精品vA| 思思久久99热免费精品6| 一本一本久久A久久综合精品 | 狠狠久久亚洲欧美专区| 潮喷大喷水系列无码久久精品| 国产女人aaa级久久久级| 伊人色综合九久久天天蜜桃| 国产精品女同久久久久电影院| 久久国产乱子精品免费女| 久久99国产一区二区三区| 99久久国产精品免费一区二区| 97久久天天综合色天天综合色hd| 久久久久噜噜噜亚洲熟女综合| 亚洲午夜无码久久久久| 久久国产成人精品麻豆| 久久综合亚洲色一区二区三区| 久久人人爽人人精品视频 | 久久精品无码一区二区三区日韩| 久久综合鬼色88久久精品综合自在自线噜噜 | 欧洲人妻丰满av无码久久不卡| 国产巨作麻豆欧美亚洲综合久久| 久久精品国产亚洲av麻豆图片| 精品久久国产一区二区三区香蕉 | 色综合合久久天天综合绕视看 | 久久国产精品免费一区| 国产V亚洲V天堂无码久久久| 亚洲第一永久AV网站久久精品男人的天堂AV | 中文字幕无码久久精品青草| 久久国产精品无码一区二区三区 | 久久精品亚洲福利| 久久青青草原精品影院| 久久青草国产精品一区| 精品久久久久中文字幕日本| 久久久一本精品99久久精品88| 亚洲精品国产字幕久久不卡| 日韩欧美亚洲综合久久影院Ds |