COPYFILE2_EXTENDED_PARAMETERS_V2结构(winbase.h)
包含 CopyFile2 函数的 COPYFILE2_EXTENDED_PARAMETERS 结构之外的更新的其他功能。
语法
typedef struct COPYFILE2_EXTENDED_PARAMETERS_V2 {
DWORD dwSize;
DWORD dwCopyFlags;
BOOL *pfCancel;
PCOPYFILE2_PROGRESS_ROUTINE pProgressRoutine;
PVOID pvCallbackContext;
DWORD dwCopyFlagsV2;
ULONG ioDesiredSize;
ULONG ioDesiredRate;
LPPROGRESS_ROUTINE pProgressRoutineOld;
PCOPYFILE2_CREATE_OPLOCK_KEYS SourceOplockKeys;
#if ...
PVOID reserved[6];
#elif
PVOID reserved[7];
#else
PVOID reserved[8];
#endif
} COPYFILE2_EXTENDED_PARAMETERS_V2;
成员
dwSize
包含此结构的大小,sizeof(COPYFILE2_EXTENDED_PARAMETERS_V2)
。
dwCopyFlags
包含这些标志值的零个或多个组合。
价值 | 意义 |
---|---|
COPY_FILE_FAIL_IF_EXISTS0x00000001 |
如果目标文件存在,复制操作将立即失败。 如果存在具有目标名称的文件或目录,则 CopyFile2 函数调用将失败,并 HRESULT_FROM_WIN32(ERROR_ALREADY_EXISTS) 或 HRESULT_FROM_WIN32(ERROR_FILE_EXISTS) 。 如果还指定了 COPY_FILE_RESUME_FROM_PAUSE,则仅当目标文件没有有效的重启标头时,才会触发失败。 |
COPY_FILE_RESTARTABLE0x00000002 |
如果再次使用同一源文件名和目标文件名,则可以以重新启动的方式复制该文件。 速度较慢。 |
COPY_FILE_OPEN_SOURCE_FOR_WRITE0x00000004 |
复制该文件,并打开源文件进行写入访问。 |
COPY_FILE_ALLOW_DECRYPTED_DESTINATION0x00000008 |
即使目标文件无法加密,也会尝试复制。 |
COPY_FILE_COPY_SYMLINK0x00000800 |
如果源文件是符号链接,则目标文件也是指向源符号链接所在的同一文件的符号链接。 |
COPY_FILE_NO_BUFFERING0x00001000 |
复制是使用未缓冲的 I/O 执行的,绕过系统缓存资源。 对于非常大的文件副本,建议使用此标志。 不建议暂停使用此标志的副本。 |
COPY_FILE_REQUEST_SECURITY_PRIVILEGES0x00002000 |
尝试复制,为源文件指定 ACCESS_SYSTEM_SECURITY ,并为目标文件指定 ACCESS_SYSTEM_SECURITY \| WRITE_DAC \| WRITE_OWNER 。 如果拒绝这些请求,则访问请求将减少到向其授予访问权限的最高特权级别。 有关详细信息,请参阅 SACL 访问权限。 这可用于允许 CopyFile2ProgressRoutine 回调执行需要更高权限的操作,例如复制文件的安全属性。 |
COPY_FILE_RESUME_FROM_PAUSE0x00004000 |
将检查目标文件,以查看是否已使用 COPY_FILE_RESTARTABLE复制它。 如果是这样,复制将恢复。 如果不是,将完全复制该文件。 |
COPY_FILE_NO_OFFLOAD0x00040000 |
请勿尝试使用 Windows 复制卸载机制。 通常不建议这样做。 |
COPY_FILE_IGNORE_EDP_BLOCK0x00400000 |
如果目标文件系统支持,则应在目标上复制和加密文件,而不是阻止该文件。 windows 10 及更高版本支持 。 |
COPY_FILE_IGNORE_SOURCE_ENCRYPTION0x00800000 |
忽略源文件的加密状态。 windows 10 及更高版本支持 。 |
COPY_FILE_DONT_REQUEST_DEST_WRITE_DAC0x02000000 |
不要请求WRITE_DAC目标文件访问。 windows 10 及更高版本支持 。 |
COPY_FILE_OPEN_AND_COPY_REPARSE_POINT0x00200000 |
无论类型如何,始终复制重新分析点。 这是调用方理解重新分析点的含义的责任。 Windows 10 版本 19041 及更高版本上受支持。 |
COPY_FILE_DIRECTORY0x00000080 |
指示源文件是目录文件。 提供时,源文件将打开 FILE_OPEN_FOR_BACKUP_INTENT 。 目录文件将具有其备用数据流、重新分析点信息和像普通文件一样复制的 EA。
Windows 10 版本 19041 及更高版本中受支持。 |
COPY_FILE_SKIP_ALTERNATE_STREAMS0x00008000 |
请勿复制备用数据流。 Windows 10 版本 19041 及更高版本中受支持。 |
COPY_FILE_DISABLE_PRE_ALLOCATION0x04000000 |
在执行复制之前,请勿预先分配目标文件大小。 Windows 10 版本 19041 及更高版本中受支持。 |
COPY_FILE_ENABLE_LOW_FREE_SPACE_MODE0x08000000 |
启用 LowFreeSpace 模式。 不使用重叠的 I/O。 不会尝试 ODX 和 SMB 卸载。 Windows 10 版本 19041 及更高版本中受支持。 |
COPY_FILE_REQUEST_COMPRESSED_TRAFFIC0x10000000 |
请求基础传输通道在复制操作期间压缩数据。 对于所有媒体,请求可能不受支持,在这种情况下,它将被忽略。 压缩属性和参数(计算复杂性、内存使用情况)无法通过此 API 进行配置,并且可能会在不同的 OS 版本之间更改。 此标志是在 Windows 10 版本 1903 和 Windows Server 2022 中引入的。 在 Windows 10 上,SMB 共享上的文件支持该标志,其中协商的 SMB 协议版本为 SMB v3.1.1 或更高版本。 |
COPY_FILE_ENABLE_SPARSE_COPY0x20000000 |
在复制过程中启用保留文件的稀疏状态。 Windows 11 版本 22H2 及更高版本中受支持。 |
pfCancel
如果此标志设置为在复制操作期间 TRUE,则会取消复制操作。
pProgressRoutine
每次复制文件另一部分时调用的 PCOPYFILE2_PROGRESS_ROUTINE 类型的回调函数的可选地址。 此参数可以 NULL。 有关进度回调函数的详细信息,请参阅 CopyFile2ProgressRoutine 回调函数。 如果同时提供 pProgressRoutineOld 和 pProgressRoutine,pProgressRoutineOld 优先。
pvCallbackContext
指向要传递给 CopyFile2ProgressRoutine的应用程序特定上下文信息的指针。
dwCopyFlagsV2
包含这些标志值的零个或多个组合。
价值 | 意义 |
---|---|
COPY_FILE2_V2_DONT_COPY_JUNCTIONS0x00000001 |
禁用复制交接点。 |
ioDesiredSize
自选。 每个 I/O 操作的请求大小(以字节为单位),即复制文件时的一个读/写周期。 如果内存不足可用,可能会降低此限制。 如果为零,则使用默认大小。 如果还提供了 ioDesiredRate,则可能会忽略此问题
ioDesiredRate
自选。 请求的平均 I/O 速率(以 KB/秒为单位)。 如果为零,则尽快执行副本。
pProgressRoutineOld
SourceOplockKeys
reserved[6]
reserved[7]
reserved[8]
pProgressRoutineOld。 自选。 LPPROGRESS_ROUTINE 类型的旧式回调函数的地址,每次复制文件的另一部分时都会调用该函数。 此参数可以 NULL。 有关详细信息,请参阅进度回调函数 LPPROGRESS_ROUTINE 回调。 如果同时提供 pProgressRoutineOld 和 pProgressRoutine,pProgressRoutineOld 优先。
言论
若要编译使用此结构的应用程序,请将 _WIN32_WINNT 宏定义为 _WIN32_WINNT_WIN8 或更高版本。 有关详细信息,请参阅 使用 Windows 标头。
要求
要求 | 价值 |
---|---|
最低支持的客户端 | Windows 11 [桌面应用 |UWP 应用] |
支持的最低服务器 | Windows Server 2012 [桌面应用 |UWP 应用] |
标头 | winbase.h (包括 Windows.h) |
另请参阅
使用 Windows 标头