• <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函數,當然在完成時,也不必有一個內存的磁盤文件拷貝。
              回復  更多評論
              

            东方aⅴ免费观看久久av| 久久精品九九亚洲精品天堂| 久久精品国产精品亚洲下载 | 国产精品久久久久久一区二区三区| 色8久久人人97超碰香蕉987| 99久久精品国产麻豆| 久久精品综合一区二区三区| 久久天天躁夜夜躁狠狠| 日本精品久久久中文字幕| 天堂无码久久综合东京热| 久久偷看各类wc女厕嘘嘘| 精品视频久久久久| 91精品国产9l久久久久| 久久人人添人人爽添人人片牛牛| 精品久久久久久成人AV| 婷婷久久综合九色综合绿巨人| 日韩乱码人妻无码中文字幕久久| 国产精品青草久久久久福利99| 久久久www免费人成精品| 91精品日韩人妻无码久久不卡| 久久精品国产99久久久古代| 国产农村妇女毛片精品久久 | 国内精品久久久久久不卡影院| 伊人久久无码中文字幕| 日韩久久久久中文字幕人妻| 久久99国产精一区二区三区| 亚洲人成网亚洲欧洲无码久久| 青春久久| 久久中文字幕视频、最近更新| 欧美一区二区精品久久| 99久久99久久| 久久se精品一区精品二区| 精品久久久久久国产潘金莲 | 久久国产精品久久国产精品| 久久天天躁狠狠躁夜夜网站 | 夜夜亚洲天天久久| 精品国产91久久久久久久| 99久久超碰中文字幕伊人| 久久久久久亚洲精品无码| 久久夜色tv网站| 久久久久久久尹人综合网亚洲|