我正在使用AssembliyDefinition.ReadAssembly加载两个程序集
在AssemblyA中,我定义了ClassA.
在AssemblyB中,我定义了ClassB:ClassA.
当我检查ClassB的TypeDefinition.BaseType时,我得到它的Module是AssemblyB.
我希望它的模块是AssemblyA,因为ClassB的基类型是ClassA,它在AssemblyA中定义.
这显示为我的错误,因为当我尝试执行classB.BaseType.Resolve()时,我得到一个错误,这可能发生,因为它在错误的程序集中搜索ClassA.
任何人的想法?
谢谢
你的期望是不正确的.
丝丝,不像的System.Reflection,以及用于一个模块,使得该模块中定义的类型之间的区别:类型定义,并且在另一个模块中定义的类型:一个TypeReference.
这就是BaseType是TypeReference实例的原因,在您的情况下,对ClassA的引用在AssemblyB中.如果要查看定义BaseType的位置,而不是使用它的位置,则必须使用TypeReference的Scope属性.
如果Resolve中有错误,那就完全不同了.但是你没有显示这个错误是什么,所以我们必须猜测程序集解析器不知道在哪里寻找AssemblyA.根据你的评论,就是这样.这是你可以做的:
var resolver = new DefaultAssemblyResolver ();
resolver.AddSearchDirectory ("path/to/AssemblyA");
resolver.AddSearchDirectory ("path/to/AssemblyB");
var a = AssemblyDefinition.ReadAssembly (
"path/to/AssemblyA/AssemblyA.dll",
new ReaderParameters { AssemblyResolver = resolver });
var b = AssemblyDefinition.ReadAssembly (
"path/to/AssemblyB/AssemblyB.dll",
new ReaderParameters { AssemblyResolver = resolver });
Run Code Online (Sandbox Code Playgroud)
这样,您可以确保所有程序集共享一个公共解析程序,该解析程序知道在哪里可以找到程序集.Resolve工作得很好.