内存映射文件并不是简单的文件I/O *** 作,实际用到了Windows的核心编程技术--内存管理。所以,如果想对内存映射文件有更深刻的认识,必须对Windows *** 作系统的内存管理机制有清楚的认识,下面给出使用内存映射文件的一般方法:
首先要通过CreateFile()函数来创建或打开一个文件内核对象,这个对象标识了磁盘上将要用作内存映射文件的文件。在用CreateFile()将文件映像在物理存储器的位置通告给 *** 作系统后,只指定了映像文件的路径,映像的长度还没有指定。为了指定文件映射对象需要多大的物理存储空间还需要通过CreateFileMapping()函数来创建一个文件映射内核对象以告诉系统文件的尺寸以及访问文件的方式。在创建了文件映射对象后,还必须为文件数据保留一个地址空间区域,并把文件数据作为映射到该区域的物理存储器进行提交。由MapViewOfFile()函数负责通过系统的管理而将文件映射对象的全部或部分映射到进程地址空间。此时,对内存映射文件的使用和处理同通常加载到内存中的文件数据的处理方式基本一样,在完成了对内存映射文件的使用时,还要通过一系列的 *** 作完成对其的清除和使用过资源的释放。这部分相对比较简单,可以通过UnmapViewOfFile()完成从进程的地址空间撤消文件数据的映像、通过CloseHandle()关闭前面创建的文件映射对象和文件对象。
HANDLE hFile = CreateFile( ...)HANDLE hMapOjb = CreateFileMapping( hFile, null, PAGE_READWRITE|SEC_RESERVE, 0, 0, null)
TCHAR* pBuf = (LPTSTR) MapViewOfFile( hMapObj, FILE_MAP_WRITE, 0, OFFSET, 10MB)
然后就对 pBuf进行 *** 作。
注意控制参数的调整,
1)CreateFile: GENERIC_READ | GENERIC_WRITE2)CreateFileMapping: PAGE_READWRITE
3)MapViewOfFile: FILE_MAP_READ | FILE_MAP_WRITE
有一点很奇怪,如果是读文件的话,应该只需要读标志就可以了。可是以上三个函数还是需要有写标志,否则读数据会失败。 那是我多年前在写程序时,要读文件。可结果总是失败,因为程序大,一直没找到错误,最终将断点调试到了内存映射这里,发觉我认为绝不会错的内存映射居然会失败。后来将写标志也指定了,错误排除。自此之后,用内存映射时,我就一直使用读写标志。楼主可以自己试一下,我说得不一定正确。因为,之后,我也从来没有去认真测试过,是不是只指定读标志,就会读失败。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)