dim mFileHwndA as long
dim mFilePathA as string
dim mFileHwndB as long
dim mFilePathB as stringmFilePathA="c:\111.dat"
mFilePathB="c:\222.dat"mFileHwndA = CreateFile(mTempFilePath, GENERIC_READ Or GENERIC_WRITE, 0, sa, CREATE_ALWAYS, FILE_ATTRIBUTE_HIDDEN, 0&)mFileHwndB = CreateFile(strFilePath, GENERIC_READ Or GENERIC_WRITE, 0, sa, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0&)现在我要把mFileHwndA句柄的文件内容写入到mFileHwndB句柄文件中,我现在的做法是首先
CloseHandle mFileHwndA
CloseHandle mFileHwndB
然后再
CopyFile mFilePathA,mFilePathB,0然后再重新打开两个文件,不过这样不仅麻烦,而且两个文件的句柄都变了!!
如果在不关闭的情况下直接快速写入,考虑到文件可能会比较大(比如100MB),如果一次读入byte数组可能会内存溢出。谢谢了,顺祝CSDN上面的朋友新年快乐!!
dim mFilePathA as string
dim mFileHwndB as long
dim mFilePathB as stringmFilePathA="c:\111.dat"
mFilePathB="c:\222.dat"mFileHwndA = CreateFile(mTempFilePath, GENERIC_READ Or GENERIC_WRITE, 0, sa, CREATE_ALWAYS, FILE_ATTRIBUTE_HIDDEN, 0&)mFileHwndB = CreateFile(strFilePath, GENERIC_READ Or GENERIC_WRITE, 0, sa, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0&)现在我要把mFileHwndA句柄的文件内容写入到mFileHwndB句柄文件中,我现在的做法是首先
CloseHandle mFileHwndA
CloseHandle mFileHwndB
然后再
CopyFile mFilePathA,mFilePathB,0然后再重新打开两个文件,不过这样不仅麻烦,而且两个文件的句柄都变了!!
如果在不关闭的情况下直接快速写入,考虑到文件可能会比较大(比如100MB),如果一次读入byte数组可能会内存溢出。谢谢了,顺祝CSDN上面的朋友新年快乐!!
解决方案 »
- 【分享】再谈VB中的多线程
- 为什么在代码窗体鼠标显示正常,而在界面窗体鼠标就变成十字了?
- 在VB的报表设计中,如果宽度大于报表宽度,如何换行啊!
- SQL数据库问题?急
- 请问一个有关文件读写的问题?
- 关于软件注册码的问题
- 能否在active report中添加控件数组?
- 错误 BOF或EOF中有一个是真,或者但前的记录已被删除
- 把事先做好的几个工程中的窗体(每个工程中只有一个窗体,并且没有改名)导入同一个新工程组成应用程序,为了不破坏原来的窗体,要注意些什么问题?
- 一个十分简单的问题,我会感谢各位并且一定给分!!!
- InternetSetOption(hRequest, INTERNET_OPTION_CONNECT_TIMEOUT,....)怎么设置连接超时啊?
- 求助
再将文件映射地址(MapViewOfFile)传给WriteFile这样就不需要自己建缓冲区、不需要自己写代码
而且效率更高CreateFileMapping VB声明
Declare Function CreateFileMapping Lib "kernel32" Alias "CreateFileMappingA" (ByVal hFile As Long, lpFileMappigAttributes As SECURITY_ATTRIBUTES, ByVal flProtect As Long, ByVal dwMaximumSizeHigh As Long, ByVal dwMaximumSizeLow As Long, ByVal lpName As String) As Long
说明
创建一个新的文件映射对象
返回值
Long,新建文件映射对象的句柄;零意味着出错。会设置GetLastError。即使函数成功,但倘若返回的句柄属于一个现成的文件映射对象,那么GetLastError也会设置成ERROR_ALREADY_EXISTS。在这种情况下,文件映射的长度就是现有对象的长度,而不是这个函数指定的尺寸
参数表
参数 类型及说明
hFile Long,指定欲在其中创建映射的一个文件句柄。&HFFFFFFFF&表示在内存中创建一个文件映射
lpFileMappigAttributes SECURITY_ATTRIBUTES,指定一个安全对象,在创建文件映射时使用。如果为NULL(用ByVal As Long传递零),表示使用默认安全对象
flProtect Long,下述常数之一:
PAGE_READONLY 以只读方式打开映射
PAGE_READWRITE 以可读、可写方式打开映射
PAGE_WRITECOPY 为写操作留下备份
可组合使用下述一个或多个常数
SEC_COMMIT 为文件映射一个小节中的所有页分配内存
SEC_IMAGE 文件是个可执行文件
SEC_RESERVE 为没有分配实际内存的一个小节保留虚拟内存空间
dwMaximumSizeHigh Long,文件映射的最大长度(高32位)
dwMaximumSizeLow Long,文件映射的最小长度(低32位)。如这个参数和dwMaximumSizeHigh都是零,就用磁盘文件的实际长度
lpName String,指定文件映射对象的名字。如存在这个名字的一个映射,函数就会打开它。用vbNullString创建一个无名的文件映射
MapViewOfFile, MapViewOfFileEx VB声明
Declare Function MapViewOfFile& Lib "kernel32" (ByVal hFileMappingObject As Long, ByVal dwDesiredAccess As Long, ByVal dwFileOffsetHigh As Long, ByVal dwFileOffsetLow As Long, ByVal dwNumberOfBytesToMap As Long)
Declare Function MapViewOfFileEx& Lib "kernel32" (ByVal hFileMappingObject As Long, ByVal dwDesiredAccess As Long, ByVal dwFileOffsetHigh As Long, ByVal dwFileOffsetLow As Long, ByVal dwNumberOfBytesToMap As Long, lpBaseAddress As Any)
说明
将一个文件映射对象映射到当前应用程序的地址空间。MapViewOfFileEx允许我们指定一个基本地址来进行映射
返回值
Long,文件映射在内存中的起始地址。零表示出错。会设置GetLastError
参数表
参数 类型及说明
hFileMappingObject Long,文件映射对象的句柄
dwDesiredAccess Long,下述常数之一:
FILE_MAP_WRITE 映射可读可写。文件映射对象必须通过PAGE_READWRITE访问创建
FILE_MAP_READ 映射只读。文件映射对象必须通过PAGE_READ 或 PAGE_READWRITE访问创建
FILE_MAP_ALL_ACCESS 与FILE_MAP_WRITE相同
FILE_MAP_COPY 映射时保留写操作的副本。文件映射对象必须用PAGE_WRITECOPY访问在win95下创建
dwFileOffsetHigh Long,文件中映射起点的高32位地址
dwFileOffsetLow Long,文件中映射起点的低32位地址
dwNumberOfBytesToMap Long,文件中要映射的字节数。用零映射整个文件映射对象
lpBaseAddress Long,指定映射文件映射对象的地址。如这个地址处没有足够的内存空间,那么对MapViewOfFileEx的调用会失效。零表示允许windows寻找一个地址
注解
dwFileOffsetLow和dwFileOffsetHigh必须反映一个偏移距离,它由系统的内存分配精度决定。例如,假设系统的内存精度是64KB(即最小分配单位是64KB),则这些值必须是64KB的整数倍。大多数应用程序都简单的用零从文件的起始处开始映射。lpBaseAddress也必须是内存分配精度的整数倍
其他
声明中的参数类型为Any,而参数表中都是Long,我也不明白。但关于这个函数的英文资料的确是这样的。