今天在学习插件系统设计的时候遇到一个问题:“System.Reflection.ReflectionTypeLoadException: 无法加载一个或多个请求的类型。
于是百度一下,很多内容都差不多,摘抄一个:
------------------------------
今天突然遇到“System.Reflection.ReflectionTypeLoadException: 无法加载一个或多个请求的类型。有关更多信息,请检索 LoaderExceptions 属性。”这样的报错,找了好长时间,上网搜索按照他们的方法好像都不能解决问题。
于是坐下来仔细一想,自己只是改了接口,多了个方法,重新生成解决方案,没有错误,但是在去反射继承这个接口的dll时忘了替换掉原来的这几个文件,反射
时原来的DLL少了一个方法,这样反射时就会错误。把重新生成的DLL复制到反射的目录下,结果问题解决了,记下来,以后出现这个问题好去解决^o^!
------------------------
重新拷贝了一份还是不行,于是也静静地想了半天,才发现因为是随便测试一 下,所以在建程序时,把接口在宿主中建立了,后来觉得不妥,又把这个文件拖动到新建的类库里。而在宿主中声明时没有加入限定词(命名空间)所以结果是插件 里与宿主里用的接口内容虽然是一样的。但命名空间是不一样的。故出现上述问题。
唉,用以前一位同事的话说就是自己给自己下绊把自己拌倒,哈哈。挺绕口的。看来以后真的要多加注意了!
****
LoaderException的解决方法
一、问题描述:
利用反射机制得到程序集的所有类型,常常会出现下面的问题。代码如下:
Assembly pAssembly = System.Reflection.Assembly.LoadFile(pfilepath);
Type[] pTypes = pAssembly.GetTypes(); //运行到这个地方会弹出如下错误描述
错误描述如下:
“未处理 System.Reflection.ReflectionTypeLoadException Message="无法加载一个或多个请求的类型。有关更多信息,请检索LoaderExceptions属性。”
二、问题分析:
小弟我在一个项目中写一些类,编译生成了一个dll,利用反射机制得到了它的所有类型,运行正常。后来再加了一个类A,其继承自类B(类B位于另一 个项目中),再编译生成,一切OK。可是利用自己编写的反射工具去得到它的类型时却出现上述错误,迷惑了一阵子,心中大呼:怪哉!后来终于找到问题元凶, 请看下述解决方法。
三、解决方法:
问题的主要原因出在:跨程序集反射。
即我们需反射的A.dll的程序集引用B.dll程序集,而在反射工具项目中却不存在对B.dll程序集的引用。因此我们只需在反射工具项目中添加对B.dll的引用即可,或者将B.dll拷贝到反射工具的执行目录下。