- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解Python异常处理中的Finally else的功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Python使用Try Exception来处理异常机制 若Exception中有Try对应的异常处理,则Try - exception之后的代码将被执行,但若Try - exception中没有对应的代码,则程序抛出Traceback停止运行 那么else finally就是针对这两种情况带来的后果分别相应的关键字 。
else 。
如果一个Try - exception中,没有发生异常,即exception没有执行,那么将会执行else语句的内容 。
反之,如果触发了Try - exception(异常在exception中被定义),那么将会执行exception中的内容,而不执行else中的内容 。
下面代码在python 3中运行通过 。
1
2
3
4
5
6
|
try
:
a
=
1
/
0
except
ZeroDivisionError:
print
(
"Division is 0 ,Wrong!"
)
else
:
print
(
"Program is running here!"
)
|
由于此时触发了Try - exception,所以执行exception 。
不执行else 。
输出结果:Division is 0 ,Wrong.
1
2
3
4
5
6
|
try
:
a
=
1
/
1
except
ZeroDivisionError:
print
(
"Division is 0 ,Wrong!"
)
else
:
print
(
"Program is running here!"
)
|
同理,这段代码由于try中无异常,所以执行else语句 。
输出结果:Program is running here.
所以如果try中的异常在exception中被指出,那么:
Try - exception-else中,执行了exception不执行else,执行else不执行exception.
或者这么理解:
作者希望Try - exception是指出错误的,如果Try - exception并没有指出错误,则是另外(else)的情况,所以执行else语句 。
finally 。
如果try中的异常没有在exception中被指出,那么系统将会抛出Traceback(默认错误代码),并且终止程序,接下来的所有代码都不会被执行,但如果有Finally关键字,则会在程序抛出Traceback之前(程序最后一口气的时候),执行finally中的语句。这个方法在某些必须要结束的操作中颇为有用,如释放文件句柄,或释放内存空间等.
1
2
3
4
5
6
|
try
:
a
=
1
/
'1'
except
ZeroDivisionError:
print
(
"Division is 0 ,Wrong!"
)
else
:
print
(
"Program is running here!"
)
|
这个程序会输出Traceback Traceback (most recent call last): File “*********************, line 2, in a = 1 / ‘1' TypeError: unsupported operand type(s) for /: ‘int' and ‘str' 。
因为try中的异常没有在exception中被指出,如果改为下面程序 。
1
2
3
4
5
6
|
try:
a = 1 / '1'
except ZeroDivisionError:
print("Division is 0 ,Wrong!")
finally:
print("Program is running here!")
|
输出结果:
Traceback (most recent call last): File “********************”, line 2, in a = 1 / ‘1' TypeError: unsupported operand type(s) for /: ‘int' and ‘str' Program is running here.
可见,即使Traceback没有消除,但依旧输出了print语句,这就是相当于一个程序的收尾工作(finally) 。
而且如果程序没有任何错误,finally也会执行 。
所以可以这么理解:
不管程序有没有异常,finally中的语句必会执行.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://blog.csdn.net/qq_40860784/article/details/78882949 。
最后此篇关于详解Python异常处理中的Finally else的功能的文章就讲到这里了,如果你想了解更多关于详解Python异常处理中的Finally else的功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 2 年前。 Improve this q
1.final final修饰类,说明这个类不能被继承,是以个顶级类。 final修饰变量,说明这个变量是常量。 final修饰方法,表示这个方法不能被重写,不过可以冲在final方法。 比如有个
我喜欢使用 -Wsuggest-final-types 编译我的代码和 -Wsuggest-final-methods以便在可能使用 final 关键字以允许编译器更积极地优化的机会时收到警告。 不过
我在 Java 8 中有一个异步操作,它返回一个 onError 回调或一个 onSuccess 回调。如果操作成功与否,我需要在我的方法内部返回。所以我返回一个 boolean 值来说明这个信息。我
我正在阅读一些内容,需要对最终类和方法进行一些说明。我的理解是,将一个类声明为 final 会阻止该类被扩展。因此,是否有必要将最终类中的方法声明为最终的?在我看来,如果类不能扩展,则没有必要将方法声
有什么区别 try { // action A } catch(Exception e) { // action B } finally { // action C }
这个程序是我类(class)的最终作业,我无法弄清楚为什么我收到错误“从内部类引用的局部变量必须是最终的或有效的最终”。该程序正在运行并发线程来对# 数组进行排序,然后找到该数组的高值和低值。当我在没
C++11 added final. 终于! 我了解 final 做了两件事: 使类不可继承。 使类中的(虚拟)函数不可覆盖(在派生类中)。 这两者似乎是相互独立的。但以以下为例: class Foo
我想使用具有多个提交按钮的react-final-form构建表单,其中每个提交按钮在表单中设置不同的值。本质上,我想创建一个在呈现的HTML中看起来像这样的表单: Are you over 1
我想知道什么时候应该对变量和(或)方法使用静态、最终、静态最终参数。据我了解: final:类似于c++中的const参数。它基本上意味着值(或在方法中 - 返回值)不会改变。 静态:这意味着值(或方
我正在做一个编程类(class)项目,用于 400 行矩阵本身的矩阵乘法。我让它以顺序模式工作,该项目的目标是编写并行实现。 我有以下代码,当然,当我尝试引用内部类中的计数器 j 时,我收到一个关于
也许这是简单的问题,但我找不到答案。 声明为final的经典变量是否包含与非final变量不同的内存段? 最佳答案 我想说,谈到局部变量,基于 this answer 是不行的。 : The trut
考虑以下代码: #include class B { virtual void f() { std::cout << "Base" << '\n'; } }; class D
这个问题已经有答案了: java: Is it possible to set a lambda expression for an array of Buttons is a for loop? I
考虑这个代码片段 public class ConstantFolding { static final int number1 = 5; static final int numbe
我确定在内部类中访问的变量应该声明为final 或有效final。但在下面的情况下我很困惑。不知道是不是我理解错了。 public class MyClass { private boolea
我必须将一个 java.sql.Connection 对象传递给一个匿名内部类,这意味着我必须对它进行 final 引用。但是,我担心任何资源泄漏。 public static String foo(
我收到 SonarQube 错误:“强烈建议在此方法实现结束时调用 super.finalize(),以防父实现也必须释放一些系统资源。” 但我发现 Object 类没有实现 finalize方法。
我一般认为资源清理是在 finally block 中完成的, 最近我在一个类中发现了这个特定的代码片段,它覆盖了 Object 类'finalize()方法。 protected void fina
让我们在父类中使用这个方法: public void calculateSum(int a, final int b) { } 子类有: public void calculateSum(int a,
我是一名优秀的程序员,十分优秀!