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

            力為的技術博客

            聯系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

            ???????????????????????????????????? 如何通過FILE*操作內存文件

            /*
            問題概述:
            ? 有這樣一個第三方的庫函數void WriteDataToFile(FILE* pFile),它是向一個文件寫入數據。
            ? 現在需要通過函數WriteDataToFile生成臨時數據,但不能生成磁盤文件(需要在內存中操作)。
            ? 然后通過某種方式讀取內存中的數據。

            流程設想:
            1、
            創建一個內存文件
            獲取該內存文件的FILE*
            寫入數據
            2、
            打開該內存文件
            獲取內存文件的FILE*
            讀取內存文件的內容
            關閉
            3、
            關閉
            *********************************************************************************
            需要解決的問題:
            1. 內存文件的HANDLE是否可以轉換為FILE* (_open_osfhandle不可以)
            2. 內存文件的操作需要調用PVOID pView = MapViewOfFile(...); 通過pView才能更改內存文件之內容。
            ?? 通過FILE* 能否通過某種方式操作pView的內容
            3. 需要實現的函數(見下面的測試代碼)
            ?? FILE* GetFilePtrByMemFileHandle(HANDLE hMemFile)
            ?? void UpdateMemFile(HANDLE hMemFile)
            4. 如果該方案有問題,可以更改

            **********************************************************************************
            實現:
            ? 1.為了方便測試使用全局的文件HANDLE
            ? 2.模擬實現了WriteDataToFile函數
            ? 3.已有資料http://community.csdn.net/Expert/TopicView.asp?id=4317083

            ?1*/
            ?2#define?MF_NAME?TEXT("MF_FILE_NAME")
            ?3#define?MF_SIZE?4*1024
            ?4HANDLE?g_hMemFile?=?NULL;
            ?5//?模擬庫函數WriteDataToFile
            ?6void?WriteDataToFile(FILE*?pFile)
            ?7{
            ?8???ASSERT(pFile);
            ?9???fputs("Write?by?Lib?Function!\n",?pFile);
            10}

            11
            12BOOL?CreateMemFile()
            13{
            14g_hMemFile?=?CreateFileMapping(INVALID_HANDLE_VALUE,?
            15NULL,?PAGE_READWRITE,?0,?
            16MF_SIZE,?MF_NAME);
            17if(g_hMemFile?!=?NULL)
            18{
            19if(GetLastError()?==?ERROR_ALREADY_EXISTS)
            20{
            21TRACE("STL?MapFile?already?exists.");
            22CloseHandle(g_hMemFile);
            23return?FALSE;
            24}

            25return?TRUE;
            26}

            27return?FALSE;
            28}

            29
            30FILE*?GetFilePtrByMemFileHandle(HANDLE?hMemFile)
            31{
            32//.
            33//具體的實現
            34
            35//.
            36return?NULL;
            37}

            38void?UpdateMemFile(HANDLE?hMemFile)
            39{
            40//..
            41//需要實現
            42}

            43
            44void?Test()
            45{
            46//?1?寫內存文件
            47if(CreateMemFile()?==?FALSE)
            48return;
            49
            50?????FILE*?pFile?=?GetFilePtrByMemFileHandle(g_hMemFile);
            51?if(NULL?==?pFile)
            52?{
            53?CloseHandle(g_hMemFile);
            54?return;
            55?}

            56
            57?WriteDataToFile(pFile);
            58?//更新內存文件
            59?UpdateMemFile(g_hMemFile);
            60
            61//?2?讀內存文件
            62?HANDLE?hFile?=?OpenFileMapping(FILE_MAP_READ?|?FILE_MAP_WRITE,?FALSE,?MF_NAME);
            63?if(hFile?!=?NULL)
            64?{
            65?FILE*?pReadFile?=?GetFilePtrByMemFileHandle(hFile);
            66?if(pReadFile)
            67?{
            68?char?strBuffer[BUFSIZ];
            69????????????int?nPtCount?=?0;
            70????????????while(fgets(strBuffer,?BUFSIZ,?pReadFile)?!=?NULL)
            71{
            72TRACE(strBuffer);
            73}

            74?}

            75?CloseHandle(hFile);
            76?}

            77//?3?關閉?
            78?CloseHandle(g_hMemFile);
            79}

            80
            81
            posted on 2005-10-14 17:30 力為 閱讀(7693) 評論(11)  編輯 收藏 引用 所屬分類: 4. C++ FAQ

            評論

            # re: 如何通過FILE*操作內存文件? 2005-10-15 14:01 任我行
            關注,等你寫全了,我就來用,哈哈。
              回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-10-15 21:11 力為
            這個在CSDN上放了幾天也沒有人回答
            是不是太難了呢?  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-10-17 15:50 moonriver
            不理解為什么要這樣干? 能否把BACKGROUND將清楚些!  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-10-19 15:02 力為
            background:
            1. 使用第三方的接口生成某種格式的文件
            2. 自己從該文件中分析需要的數據
            3. 該文件為中間文件并不需要放在磁盤之上


            故用內存文件保存臨時數據
              回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-12-04 14:43 hehehe
            不理解啊!把文件讀入緩沖區,再處理緩沖區中的文件,是這個意思嗎?  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-12-05 09:14 力為
            也可以這樣認為。
            只不過通過FILE如何把內容寫入緩沖區?  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-12-05 13:37 hehehe
            一般來說,我比較喜歡這個函數。。。
            BOOL ReadFile(
            HANDLE hFile, // handle of file to read
            LPVOID lpBuffer, // pointer to buffer that receives data
            DWORD nNumberOfBytesToRead, // number of bytes to read
            LPDWORD lpNumberOfBytesRead, // pointer to number of bytes read
            LPOVERLAPPED lpOverlapped // pointer to structure for data
            );
            那個lpBuffer就是指向緩沖區的指針,要在內存中操作文件,我就用這個。。。  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2005-12-05 13:50 力為
            但C語言的FILE*如何往緩沖區寫內容呢?  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2006-01-07 10:27 力為
            在懸掛了N月之后,我為此題下了結論:此題無解!:(  回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2006-01-22 15:20 stronger
            https://sourceforge.net/project/shownotes.php?release_id=340318

              回復  更多評論
              

            # re: 如何通過FILE*操作內存文件? 2010-10-08 01:44 macostar_wzy
            內存映射API函數CreateFileMapping創建一個有名的共享內存:
            HANDLE CreateFileMapping(
            HANDLE hFile, // 映射文件的句柄,
            //設為0xFFFFFFFF以創建一個進程間共享的對象
            LPSECURITY_ATTRIBUTES lpFileMappingAttributes, // 安全屬性
            DWORD flProtect, // 保護方式
            DWORD dwMaximumSizeHigh, //對象的大小
            DWORD dwMaximumSizeLow,
            LPCTSTR lpName // 必須為映射文件命名
            );
            要把文件映像到內存,首先必須調用CreateFileMapping()函數,它需要用一個由CreateFile()函數打開并返回的文件句柄,對大多數共享內存的應用程序,必須把此句柄設置為0xFFFFFFFF,用來指定系統頁面文件。通過使用上面的特殊句柄,0XFFFFFFFF是INVALID_HANDLE_VALUE,表示不指定文件,在系統分頁文件(pagefile.sys)中分配映射的磁盤空間,可以不調用CreateFile函數,當然在完成時,也不必有一個內存的磁盤文件拷貝。
              回復  更多評論
              

            亚洲伊人久久成综合人影院 | 精品国产日韩久久亚洲| 久久久久99精品成人片三人毛片 | 一本一道久久综合狠狠老| 久久天天躁狠狠躁夜夜躁2O2O| 国产精品久久久久国产A级| 成人a毛片久久免费播放| 久久这里有精品| 久久免费精品视频| 久久精品国产亚洲AV忘忧草18| 久久青青草原亚洲av无码app| 国产精品美女久久久免费| 久久久久久国产精品无码下载 | 久久久久九九精品影院| 性高湖久久久久久久久| 久久一区二区三区免费| 国产欧美一区二区久久| 久久久国产打桩机| 久久精品无码一区二区三区日韩 | 久久99精品久久久久久hb无码 | 精品熟女少妇AV免费久久| 精品人妻伦一二三区久久| 91精品国产综合久久婷婷| 久久精品国产乱子伦| 久久久网中文字幕| 久久精品一区二区三区不卡| 婷婷五月深深久久精品| 午夜天堂av天堂久久久| 精品无码久久久久国产动漫3d| 久久国产成人| 久久久久国色AV免费看图片| 久久国产福利免费| 久久国产精品一区| 久久青草国产精品一区| 一本大道久久a久久精品综合| 丰满少妇人妻久久久久久 | 热99RE久久精品这里都是精品免费| 久久se精品一区二区影院| 欧美大战日韩91综合一区婷婷久久青草| 国产精品永久久久久久久久久 | 久久免费国产精品一区二区|