SymSrvDeltaNameW 函数 (dbghelp.h)

为描述同一符号或映像文件的两个不同版本之间的关系的文件生成名称。 使用此功能可防止应用程序每次分析两个文件时重新生成此类信息。

语法

PCWSTR IMAGEAPI SymSrvDeltaNameW(
  [in]           HANDLE hProcess,
  [in, optional] PCWSTR SymPath,
  [in]           PCWSTR Type,
  [in]           PCWSTR File1,
  [in]           PCWSTR File2
);

参数

[in] hProcess

进程的句柄。 此句柄以前必须传递给 SymInitialize 函数。

[in, optional] SymPath

符号路径。 该函数仅使用符号存储的标准语法中所述的符号存储。 将忽略所有其他路径。 如果此参数 NULL,则该函数使用 SymInitializeSymSetSearchPath 函数设置的符号路径。

[in] Type

生成的文件名的扩展名。

[in] File1

符号或映像文件的第一个版本的路径。

[in] File2

符号或映像文件的第二个版本的路径。

返回值

如果函数成功,则返回值为生成的文件名。

如果函数失败,则返回值 NULL。 若要检索扩展的错误信息,请调用 GetLastError

言论

此函数打开两个指定文件,从标头读取索引信息,并将此信息传递给符号服务器,以便它可以创建文件名。 如果将 Type 参数指定为“xml”,则名称是 File1的索引,后跟短划线,后跟 File2的索引,后跟 .xml 扩展名。 例如:

3F3D5C755000-3F3D647621000.xml

此函数返回指向另一个函数可能重复使用的缓冲区的指针。 因此,请务必立即将返回的数据复制到另一个缓冲区。

所有 DbgHelp 函数(如此函数)都是单线程的。 因此,从多个线程调用此函数可能会导致意外行为或内存损坏。 若要避免这种情况,必须将来自多个线程的所有并发调用同步到此函数。

若要调用此函数的 Unicode 版本,请定义DBGHELP_TRANSLATE_TCHAR。

注意

dbghelp.h 标头将 SymSrvDeltaName 定义为一个别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将中性编码别名与不中性编码的代码混合使用可能会导致编译或运行时错误不匹配。 有关详细信息,请参阅函数原型的 约定。

要求

要求 价值
目标平台 窗户
标头 dbghelp.h
Dbghelp.lib
DLL Dbghelp.dll
可再发行组件 DbgHelp.dll 6.3 或更高版本

另请参阅

DbgHelp 函数