ICorProfiler:为什么我得到一个 jitted 函数的错误类型标记?
ICorProfiler: Why do I get the wrong type token for a jitted function?
我的代码结构如下:
class A {
void M() {}
}
delegate void B<T1,T2>(T1 key, T2 value);
我正在使用 ICorProfiler2 API 来分析该代码。现在,当方法 M 被调用时,我得到一个指向其 ID 的 FunctionID* 指针。然后我执行以下操作(粗略缩写):
mdToken functionToken = mdTypeDefNil;
mdTypeDef classToken = mdTypeDefNil;
IMetaDataImport* pMDImport = NULL;
profilerInfo->GetTokenAndMetaDataFromFunction(functionId,
IID_IMetaDataImport, (IUnknown**) &pMDImport, &functionToken);
pMDImport->GetMethodProps(functionToken, &classToken, functionName,
sizeof(functionName), 0, &methodAttr, &sigBlob, &sigSize, NULL,
NULL);
这在变量 classToken.
中给了我一个 TypeToken
我预期这是在源中声明M的类型(a.k.a class A),但我收到委托B的类型令牌。所以我的问题是:我做错了什么还是我假设 GetMethodProps returns M 的定义类型的类型标记错误?
不幸的是,GetMethodProps 的文档不是很有帮助:https://msdn.microsoft.com/en-us/library/ms233163(v=vs.110).aspx
编辑:
澄清一下:我知道返回了错误的类型,因为我生成了一个包含所有 type/function 标记及其映射到的名称的文件。我用 ILSpy 验证了这些标记:它们是正确的。此映射也在其他应用程序中经过多次测试,似乎工作正常,所以我认为这不是问题的根源。
到目前为止,没有人能够解释为什么会发生这种情况。我的所有调查让我相信探查器 API 有时只是报告方法的错误类型。
幸运的是,方法标记在整个程序集中是唯一的,因此我们现在使用这些 + 程序集名称来唯一标识每个方法并完全忽略类型标记。
我的代码结构如下:
class A {
void M() {}
}
delegate void B<T1,T2>(T1 key, T2 value);
我正在使用 ICorProfiler2 API 来分析该代码。现在,当方法 M 被调用时,我得到一个指向其 ID 的 FunctionID* 指针。然后我执行以下操作(粗略缩写):
mdToken functionToken = mdTypeDefNil;
mdTypeDef classToken = mdTypeDefNil;
IMetaDataImport* pMDImport = NULL;
profilerInfo->GetTokenAndMetaDataFromFunction(functionId,
IID_IMetaDataImport, (IUnknown**) &pMDImport, &functionToken);
pMDImport->GetMethodProps(functionToken, &classToken, functionName,
sizeof(functionName), 0, &methodAttr, &sigBlob, &sigSize, NULL,
NULL);
这在变量 classToken.
中给了我一个 TypeToken我预期这是在源中声明M的类型(a.k.a class A),但我收到委托B的类型令牌。所以我的问题是:我做错了什么还是我假设 GetMethodProps returns M 的定义类型的类型标记错误?
不幸的是,GetMethodProps 的文档不是很有帮助:https://msdn.microsoft.com/en-us/library/ms233163(v=vs.110).aspx
编辑: 澄清一下:我知道返回了错误的类型,因为我生成了一个包含所有 type/function 标记及其映射到的名称的文件。我用 ILSpy 验证了这些标记:它们是正确的。此映射也在其他应用程序中经过多次测试,似乎工作正常,所以我认为这不是问题的根源。
到目前为止,没有人能够解释为什么会发生这种情况。我的所有调查让我相信探查器 API 有时只是报告方法的错误类型。
幸运的是,方法标记在整个程序集中是唯一的,因此我们现在使用这些 + 程序集名称来唯一标识每个方法并完全忽略类型标记。