- 2013-12-10雷军微博披露小米“魔方”项目
- 2013-12-1012306购票首度接入支付宝 支付时间可以快至5秒
- 2013-12-10中国移动官网显示周四接受iPhone 5s预订
- 2013-12-0912306 App研发故事:变成开放系统 社会人员助力
- 2013-10-15天猫“双十一”今年打通线上线下:实体店参与。
- 2013-10-15根据专利显示iPhone将有防摔功能。
- 2013-10-12百度或可全面收购人人网,传闻四起!
- 2013-10-07生物密码时代何时到来?尚存隐私泄露隐忧
- 2013-09-29国务院近日印发了上海自由贸易试验区总体方案,自贸区...
- 2013-09-29移动医疗大潮袭来,看着是肉 咬下去是骨头。
ASP.NET无法捕获的异常:MissingMethodException
发表于:2013-09-15|
次阅读|
作者:藕码网
摘要:本文介绍在ASP.NET中,如果遇到了无法捕获的异常:MissingMethodException错误,该以什么思路去寻找解决办法。
本文介绍在ASP.NET中,如果遇到了无法捕获的异常:MissingMethodException错误,该以什么思路去寻找解决办法。
今天在解决一个项目问题时,遇到了问题。在系统日志里的“应用程序日志”,有一堆的异常:
异常信息:
异常类型: MissingMethodException
异常消息: 找不到方法:“nameSp.abc.xxx()”。
然后就清楚了,这个xxx方法是nameSp.dll里新增的一个方法,再确认一下这个dll,果然是没发布最新dll,用的还是旧的dll,把nameSp.dll发布后,问题排除。
这时,同事还有一个问题,他说:我的代码是类似这样的:
try{
nameSp.abc.xxx();
}catch(Exception exp){
// 记录日志
}
为什么上面的代码没有记录日志呢?
我也晕了一下,后面写一个测试程序:
文件1:
class Program
{
static void Main(string[] args)
{
try
{
new MethodNoTest().Run();
}
catch(Exception exp)
{
Console.WriteLine("外部出错:" + exp);
}
}
}
文件2:
public class MethodNoTest
{
public void Run()
{
Console.WriteLine("开始");
try
{
nameSp.abc.xxx();
}
catch (Exception exp)
{
Console.WriteLine("内部出错:" + exp);
}
Console.WriteLine("完成");
}
public void aa(){
Console.WriteLine("abc");
}
}
引用新dll编译成功后,再把旧dll拷贝到exe目录下,执行结果是:
外部出错:System.MissingMethodException:找不到方法:“void nameSp.abc.xxx()”
很奇怪吧,为什么连“开始”和“完成”都没有输出呢?
答案是编译完成的dll,只是il代码,并不是真正的机器码,.net程序在运行前还要把il代码编译转换为机器码执行,上面程序步骤:
1、Program类编译正常,执行到new MethodNoTest().Run();
2、发现MethodNoTest的Run方法未编译为机器码,开始编译,发现方法里引用的abc类没有定义xxx这个方法,就直接抛出异常,所以Run这个方法里的任何一句代码都没有执行,更不要说里面的try能起作用了。
注:本站部分信息可能源于互联网分享,如有侵权,请告知,我们将及时删除!
上一篇:ASP.NET中的字符串处理函数 下一篇:.NET框架下各成员的关系
- 用户评论
- 相关文章
-
最新评论
推荐文章
-
1
bash_profile和.bashr...
详细介绍bash_profile和.bashrc之间的区别。... -
2
awstats的安装简易指南...
介绍awstats的安装使用,使其能快速部署。 -
3
分布式监控系统gangli...
详细介绍ganglia配置过程 -
4
使用IIS+Resin来配置J...
本文介绍使用IIS+Resin来配置JSP的运行环境... -
5
MYSQL的主要参数设置(...
MYSQL的主要参数设置(优化) -
6
Linux服务器安全小技巧...
Linux 服务器安全小技巧
热门文章榜