TypeLoadException编译成功,运行时报错
表现:
代码编译成功,运行时报错。
原因:
由于代码在编译过程中的顺序问题,顶层引用的dll,在编译过程中覆盖了底层的使用的同名dll,导致了虽然底层编译时,其引用的dll是存在的,所以编译不会报错,但是在在编译顶层代码时,在bin目录中,其引用的dll覆盖了底层编译时添加的同名dll,这就出现了虽然编译过程中并没有报错,可是运行时会出现TypeLoadException (类型加载异常),因为相应的dll已经被偷偷换掉了。
备注:
这个事情发生的原因是因为其他组引用Other.dll错误导致的,之前A目录和B目录中的Temp.dll中的内容是一样,Other.dll引用的是A.Temp.dll,但是后来B.Temp.dll中有更新,但是A.Temp.dll没有更新,而我们底层引用的是B.Temp.dll,表现层引用的是Other.dll,就导致了代码编译成功,运行时报错,排错排了好久。
举例:一个解决方案有多个项目 ,项目A 引用other.dll 版本2.5.6 ,项目B 引用other.dll 版本2.4.1
项目A引用了项目B,编译成功,但这时运行报错,顶层A会报找不到某方法或引用other.dll 版本2.5.6找不到之类的错误,
解决方法:
这时需要项目A引用other.dll 版本降到2.4.1,或者B 引用other.dll 版本升到2.5.6,其实就是保持引用版本一致
注意:若按上述方法解决后 运行还报错,可能出现项目C引用项目A , 而项目C的app.config的other.dll版本号与项目A不一致,修改为与项目A相同版本号
<dependentAssembly>
<assemblyIdentity name="other" publicKeyToken="0df73ec7942b34e1" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-2.4.1.0" newVersion="2.4.1.0" />
</dependentAssembly>