Assert-info
Assert 断言函数
简介:
pthon assert 断言是声明其布尔值必须为真的判定,如果为假则抛出异常AssertionError
assert用法:
assert expression [, arguments]
使用assert断言是学习python一个非常好的习惯,python assert 断言句语格式及用法很简单。在没完善一个程序之前,我们不知道程序在哪里会出错,与其让它在运行最崩溃,不如在出现错误条件时就崩溃,这时候就需要assert断言的帮助。
用法:
>>assert 1==1
>> assert 1 == 2
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AssertionError
>>assert 2+2==2*2
>>assert len(['my boy',12])<10
>>assert range(4)==[0,1,2,3]
>>> mylist = ['item']
>>assert len(mylist) >= 1
>>mylist.pop()
'item'
>>assert len(mylist) >= 1
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AssertionError
使用误区:
1. 以assert方式作为参数异常
if not isinstance(x, int)
raise AssertionError('not an int')
# 不应该抛出断言异常应该是TypeError
# 但是,更危险的是,有一个关于assert的困扰:它可以被编译好然后从来不执行,如果你用 –O 或 – oo 选项运行Python,结果不保证assert表达式会运行到。当适当的使用assert时,这是未来,但 是当assert不恰当的使用时,它会让代码用-O执行时出错。
2.适用情形
防御性编程
运行时检查程序逻辑
检查约定
检查常量
检查文档
在测试代码的时候使用断言也是可接受的,是一种很方便的单元测试方法,你接受这些测试在用-O标志运行时不会做任何事。我有时在代码里使用assert False来标记没有写完的代码分支,我希望这些代码运行失败。尽管抛出NotImplementedError可能会更好。
3.以断言代替不必要注释
例如函数希望在执行过程中一直有数据库连接,作为不变量可以采用断言
def some_fun(args):
assert not DB.cloesd()
...
# code goes here
assert not DB.closed()
return result
断言也是一种防御型编程,为了防止以后版本的升级可能带来的错误理想情况下,单元测试可以完成这样的工作,可是需要面对的现实是,它们通常是没有完成的。人们可能在提交代码前会忘了运行测试代码。有一个内部检查是另一个阻挡错误的防线,尤其是那些不明显的错误,却导致了代码出问题并且返回错误的结果。
假如现有以下语句:
#target isexpected to be one of x, y, or z, and nothing else.
if target == x:
run_x_code()
elif
target == y:
run_y_code()
else:
run_z_code()
可以以断言代替注释,在违反时返回一个干净的错误:
assert target in (x, y, z)
if target == x:
run_x_code()
elif target == y:
run_y_code()
else:
assert target == z
run_z_code()
还有更好的方案:
if target == x:
run_x_code()
elif target == y:
run_y_code()
elif target == z:
run_z_code()
else:
# This can never happen. But just incase it does...
raise RuntimeError("anunexpected error occurred")
Last updated
Was this helpful?