首页 > 其他 > 详细

Try Catch Finally 中Finally的代码在什么时候不被执行

时间:2017-08-31 16:41:47      阅读:778      评论:0      收藏:0      [点我收藏+]
近日执行一段陈旧的代码,一个Batch执行EXE,每日无限循环。

唯一可以停掉该Batch的方法,就是直接将进程杀掉,或者在Batch的CMD窗口关掉X按钮。

 而后,进程中永远都会增加一个Excel的执行进程。 必须手动关闭。 

 想来十分愚蠢,但细读元代码后,发现在处理中有Try Catch Finally 的语句。但其Finally中

原本希望的执行的,关掉Excel进程的部分,并没有正常执行。

细读http://thedailywtf.com/articles/My-Tales后。

 

归结为:

在采取杀死进程(包括点击X按钮,Application.Exit()), 关电源, 以及系统内存泄漏等异常情况下, Finally 中

的语句不会被执行。只有正常的异常,比如文件不存在,数据库断连接等系统可预测级别的异常,才会进入Finally

因此,考虑Finally的执行语句时, 需要慎重考虑。

Try Catch Finally 中Finally的代码在什么时候不被执行

原文:http://www.cnblogs.com/tomclock/p/7459031.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!