MoveFileTransactedW 函数 (winbase.h)

[Microsoft 强烈建议开发人员使用替代方法来实现应用程序的需求。 TxF 致力于实现的许多方案都可以通过更简单、更易用的技术来实现。 此外,TxF 在 Microsoft Windows 的将来版本中可能不可用。 有关详细信息,以及 TxF 的替代方法,请参阅事务性 NTFS 的替代方法。]

将现有文件或目录(包括其子级)作为事务处理操作移动。

语法

BOOL MoveFileTransactedW(
  [in]           LPCWSTR            lpExistingFileName,
  [in, optional] LPCWSTR            lpNewFileName,
  [in, optional] LPPROGRESS_ROUTINE lpProgressRoutine,
  [in, optional] LPVOID             lpData,
  [in]           DWORD              dwFlags,
  [in]           HANDLE             hTransaction
);

参数

[in] lpExistingFileName

本地计算机上现有文件或目录的当前名称。

默认情况下,名称限制为MAX_PATH个字符。 若要将此限制扩展到 32,767 个宽字符,请在路径前面添加“\?\”。 有关详细信息,请参阅命名文件、路径和命名空间

提示

从 Windows 10 版本 1607 开始,可以选择删除MAX_PATH限制,而无需在前面添加“\\?\”。 有关详细信息,请参阅 命名文件、路径和命名空间 的“最大路径长度限制”部分。

[in, optional] lpNewFileName

文件或目录的新名称。 新名称不得已存在。 新文件可能位于不同的文件系统或驱动器上。 新目录必须位于同一驱动器上。

默认情况下,名称限制为MAX_PATH个字符。 若要将此限制扩展到 32,767 个宽字符,请在路径前面添加“\?\”。 有关详细信息,请参阅命名文件、路径和命名空间

提示

从 Windows 10 版本 1607 开始,可以选择删除MAX_PATH限制,而无需在前面添加“\\?\”。 有关详细信息,请参阅 命名文件、路径和命名空间 的“最大路径长度限制”部分。

[in, optional] lpProgressRoutine

指向每次移动文件另一部分时调用的 CopyProgressRoutine 回调函数的指针。 如果提供显示操作进度的用户界面,则回调函数会很有用。 此参数可以为 NULL。

[in, optional] lpData

要传递给 CopyProgressRoutine 回调函数的参数。 此参数可以为 NULL。

[in] dwFlags

移动选项。 此参数可使用以下一个或多个值。

含义
MOVEFILE_COPY_ALLOWED
2 (0x2)
如果要将文件移动到其他卷,该函数将使用 CopyFileDeleteFile 函数模拟移动。

如果文件已成功复制到其他卷,并且无法删除原始文件,则函数会成功使源文件保持不变。

此值不能与 MOVEFILE_DELAY_UNTIL_REBOOT 一起使用。

MOVEFILE_CREATE_HARDLINK
16 (0x10)
保留供将来使用。
MOVEFILE_DELAY_UNTIL_REBOOT
4 (0x4)
在重新启动操作系统之前,系统不会移动文件。 在执行 AUTOCHK 之后,但在创建任何分页文件之前,系统会立即移动文件。 因此,此参数使 函数能够从以前的启动中删除分页文件。

仅当进程位于属于管理员组或 LocalSystem 帐户的用户的上下文中时,才能使用此值。

此值不能与 MOVEFILE_COPY_ALLOWED 一起使用。

“备注”部分详述的对注册表值的写入操作是事务处理的内容。 当计算机重启时(事务完成后),文件移动完成。

MOVEFILE_REPLACE_EXISTING
1 (0x1)
如果存在名为 lpNewFileName 的文件,则函数将其内容替换为 lpExistingFileName 文件的内容。

如果 lpNewFileNamelpExistingFileName 命名目录,则不能使用此值。

MOVEFILE_WRITE_THROUGH
8 (0x8)
调用 MoveFileTransacted 意味着在提交操作完成时移动文件操作完成。 此标志不必要;如果指定了此标志,则不会有负面影响,但操作速度缓慢。 在磁盘上实际移动文件之前,函数不会返回 。

设置此值可确保在函数返回之前将复制和删除操作执行的移动刷新到磁盘。 刷新发生在复制操作结束时。

如果设置了 MOVEFILE_DELAY_UNTIL_REBOOT ,则此值不起作用。

[in] hTransaction

事务的句柄。 此句柄由 CreateTransaction 函数返回。

返回值

如果该函数成功,则返回值为非零值。

如果函数失败,则返回值为零。 要获得更多的错误信息,请调用 GetLastError。

跨卷移动文件时,如果 lpProgressRoutine 由于用户取消操作而返回PROGRESS_CANCEL,MoveFileTransacted 将返回零GetLastError 将返回ERROR_REQUEST_ABORTED。 现有文件保持不变。

跨卷移动文件时,如果 lpProgressRoutine 由于用户停止操作而返回PROGRESS_STOP,MoveFileTransacted 将返回零GetLastError 将返回ERROR_REQUEST_ABORTED。 现有文件保持不变。

注解

如果 dwFlags 参数指定 MOVEFILE_DELAY_UNTIL_REBOOT,则 MoveFileTransacted 如果无法访问注册表,它将失败。 函数以事务方式将重新启动时要重命名的文件的位置存储在以下注册表值中: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\控制\会话管理器\PendingFileRenameOperations

此注册表值的类型为 REG_MULTI_SZ。 每个重命名操作都存储以下 以 NULL 结尾的字符串之一,具体取决于重命名是否为删除:

szDstFile\0\0

szSrcFile\0szDstFile\0

字符串 szDstFile\0\0 指示文件 szDstFile 将在重新启动时删除。

字符串 szSrcFile\0szDstFile\0 指示 szSrcFile 将在重新启动时重命名为 szDstFile

注意 尽管在技术上不允许 在REG_MULTI_SZ 节点中使用 \0\0,但它可能是因为文件被视为重命名为空名称。
 
系统使用这些注册表项在重启时按照与其发出相同的顺序完成操作。 有关使用 MOVEFILE_DELAY_UNTIL_REBOOT 标志的详细信息,请参阅 MoveFileWithProgress

如果文件跨卷移动, MoveFileTransacted 不会随文件一起移动安全描述符。 为文件分配目标目录中的默认安全描述符。

如果指定 MOVEFILE_FAIL_IF_NOT_TRACKABLE 标志,则此函数始终失败;TxF 不支持跟踪。

在 Windows 8 和 Windows Server 2012 中,此函数由以下技术支持。

技术 支持
服务器消息块 (SMB) 3.0 协议
SMB 3.0 透明故障转移 (TFO)
具有横向扩展文件共享的 SMB 3.0 (SO)
群集共享卷文件系统 (CSV)
弹性文件系统 (ReFS)
 

SMB 3.0 不支持 TxF。

要求

要求
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2008 [仅限桌面应用]
目标平台 Windows
标头 winbase.h (包括 Windows.h)
Library Kernel32.lib
DLL Kernel32.dll

另请参阅

CopyFileTransacted

文件管理函数

MoveFileWithProgress

事务性 NTFS