注:最后有面试挑战,看看自己掌握了吗
🌸I could be bounded in a nutshell and count myself a king of infinite space.
特别鸣谢:木芯工作室 、Ivan from Russia
低级错误:代码错误 中级错误:边界值没考虑,传入数据没考虑类型 高级错误:程序运行过程中的不确定性环境因素
def print_D(dic):
i=0
try:
len1=len(dic)
while i<len1:
print(dic.popitem())
i+=1
except:
print("请传递字典!")
if '__main__' == __name__:
print_D({1:100,2:"zzz"})
print_D(1)
强制性,比sys.exit()
级别高
def print_D(dic):
i=0
try:
len1=len(dic)
while i<len1:
print(dic.popitem())
i+=1
except:
print("请传递字典!")
finally:
print("zuihou")
if '__main__' == __name__:
print_D(1)
使用特定异常判断程序出错在实际项目很少使用–不如直接编写代码的时候避免
def print_D(dic):
i=0
try:
t+=1
except(NameError):
print("没定义呢!")
finally:
print("zuihou")
if '__main__' == __name__:
print_D({1:12})
抛出以后要有处理的函数
raise Exception
def mye( level ):
if level < 1:
raise Exception("Invalid level!")
# 触发异常后,后面的代码就不会再执行
try:
mye(0) # 触发异常
except(Exception):
print(123)
else:
print(456)
通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception
类,通过直接或间接的方式。
以下为与RuntimeError
相关的实例,实例中创建了一个类,基类为RuntimeError
,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。
class Networkerror(RuntimeError):
def __init__(self, arg):
self.args = arg
在你定义以上类后,你可以触发该异常,如下所示:
try:
raise Networkerror("Bad hostname")
except Networkerror,e:
print e.args