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

            久久中文骚妇内射| 91精品国产91热久久久久福利| 久久精品中文字幕第23页| 婷婷久久综合九色综合98| 97久久精品人人澡人人爽| 色综合久久久久综合99| 伊人久久大香线蕉亚洲| 久久香蕉一级毛片| 久久久无码精品亚洲日韩蜜臀浪潮| 亚洲AV成人无码久久精品老人| 99久久综合狠狠综合久久止| 人妻少妇精品久久| 久久99国产精品久久久| 国产精品久久久久久久app| 久久91精品国产91久久户| 久久精品无码一区二区WWW| 青青青国产精品国产精品久久久久| 亚洲国产精品无码久久九九| 国产成人综合久久综合| 精品国产乱码久久久久久呢| 久久精品国产欧美日韩| 久久国产精品成人免费| 久久天堂AV综合合色蜜桃网| 亚洲伊人久久综合中文成人网| 国产精品gz久久久| 久久久久中文字幕| 久久成人国产精品二三区| 蜜臀久久99精品久久久久久小说| 久久亚洲2019中文字幕| 精品久久久久久无码人妻蜜桃| 69SEX久久精品国产麻豆| 一本一本久久aa综合精品| 波多野结衣久久一区二区| 国内精品久久久久影院亚洲| 久久精品中文字幕一区 | 久久人人爽人人爽人人片AV东京热 | 成人资源影音先锋久久资源网| 午夜精品久久久久久99热| 久久亚洲AV成人无码电影| A狠狠久久蜜臀婷色中文网| 999久久久无码国产精品|