这篇文章给大家分享的是有关.net framework 4.0环境下遇到版本不同编译不通过怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名与空间、虚拟空间、营销软件、网站建设、丰都网站维护、网站推广。最近部门的开发环境都更新到了WIN7+.NET framework4+VS2010上,在体验新技术和新环境带给我们提高效率的方式方法的同时也带来了一些兼容性的问题;这几天项目闲暇时在研究SQLite,在做实验的时候碰到个问题,代码编译通过执行时反复异常中断,查到后面原来是SQLite.dll是在framework2.0环境下编译的而现在的运行环境是framework4.0,所以就出现了运行异常,如图:
由于以后的开发过程中,可能会引用一些第三方的组件,有可能是老的framework版本下编译的,同样会出现此类的问题,所以在本文中提供一个解决办法和说明造成此问题的原因。
查阅了相关资料,stackoverflow.com上建议在config文件中增加配置:
复制代码 代码如下:
MSDN上也对此方法进行了阐述,参见http://msdn.microsoft.com/en-us/library/bbx34a2h(VS.100).aspx
但是使用此方法编译后问题仍然没有解决,但是问题可以明确锁定为.net runtime环境的问题了。
复制代码 代码如下:
再次运行,问题解决。这下需要了解是什么原因造成的?
supportedRuntime标签用来 具体说明应用程序支持的是哪个.framework运行时的版本;
requiredRuntime标签用来 具体说明应用程序只支持1.0版本的公用语言运行时间。如果使用1.1版本或者后面的版本来编译,应用程序必须使用
注意:
再次查阅CLR Runtime版本的相关资料,引用以下CLR运行规则和各版本间关系汇总表格,如下:
规则:
1. CLR4.0及以上版本编译的应用程序总是运行在应用程序所被编译的CLR版本上;
2. CLR4.0以下版本编译的应用程序优先运行在被编译的CLR版本上,如果此版本不存在,则运行新的小于CLR4.0的版本;
汇总如下:
EXE被编译的CLR版本号 | 机器上安装有CLR 1.1? | 机器上安装有CLR 2.0? | 机器上安装有CLR 4.0? | 结果 |
1.1 | 是 | 无所谓 | 无所谓 | 加载CLR 1.1 |
2.0 | 无所谓 | 是 | 无所谓 | 加载CLR 2.0 |
1.1 | 否 | 是 | 无所谓 | 加载CLR 2.0 |
1.1 | 否 | 否 | 是 | 失败 |
2.0 | 无所谓 | 否 | 是 | 失败 |
感谢各位的阅读!关于“.net framework 4.0环境下遇到版本不同编译不通过怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!