RegReplaceKeyA 函数 (winreg.h)
将支持注册表项的文件及其所有子项替换为另一个文件,以便在系统下次启动时,密钥和子项将包含存储在新文件中的值。
备份或还原系统状态(包括系统文件和注册表配置单元)的应用程序应使用 卷影复制服务 而不是注册表功能。
语法
LSTATUS RegReplaceKeyA(
[in] HKEY hKey,
[in, optional] LPCSTR lpSubKey,
[in] LPCSTR lpNewFile,
[in] LPCSTR lpOldFile
);
参数
[in] hKey
打开的注册表项的句柄。 此句柄由 RegCreateKeyEx 或 RegOpenKeyEx 函数返回,也可以是以下 预定义键之一:
HKEY_CLASSES_ROOTHKEY_CURRENT_CONFIGHKEY_CURRENT_USERHKEY_LOCAL_MACHINEHKEY_USERS
[in, optional] lpSubKey
要替换其子项和值的注册表项的名称。 如果该键存在,则它必须是由 hKey 参数标识的键的子项。 如果子项不存在,则会创建它。 此参数可以 NULL。
如果指定的子项不是 hive 的根,RegReplaceKey 遍历 hive 树结构,直到遇到 hive 根,然后将该 hive 的内容替换为由 lpNewFile指定的数据文件的内容。
有关详细信息,请参阅 注册表元素大小限制。
[in] lpNewFile
包含注册表信息的文件的名称。 此文件通常是使用 RegSaveKey 函数创建的。
[in] lpOldFile
接收要替换的注册表信息的备份副本的文件的名称。
返回值
如果函数成功,则返回值ERROR_SUCCESS。
如果函数失败,则返回值为 Winerror.h 中定义的非零错误代码。 可以将 FormatMessage 函数与FORMAT_MESSAGE_FROM_SYSTEM标志一起使用,以获取错误的泛型说明。
言论
有两种不同的注册表配置单元文件格式。 早期操作系统通常无法加载在当前操作系统上创建的注册表配置单元。
lpNewFile 参数指定的文件将保持打开状态,直到系统重新启动。
如果 hKey 是由 RegConnectRegistry返回的句柄,则 lpNewFile 中指定的路径和 lpOldFile 相对于远程计算机。
调用过程必须在注册表所在的计算机上具有SE_RESTORE_NAME和SE_BACKUP_NAME权限。 有关详细信息,请参阅 使用特殊特权运行。
注意
winreg.h 标头将 RegReplaceKey 定义为别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将中性编码别名与不中性编码的代码混合使用可能会导致编译或运行时错误不匹配。 有关详细信息,请参阅函数原型的
要求
要求 | 价值 |
---|---|
最低支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
支持的最低服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | 窗户 |
标头 | winreg.h (包括 Windows.h) |
库 | Advapi32.lib |
DLL | Advapi32.dll |