1.异常处理机制
def test(x):
try:
y = 10 / x
print(y)
#except Exception as e:
#print(e)#可以打印出异常的类型
except ZeroDivisionError: #抛出异常,执行下面的程序,如果是界面软件可以弹出一个窗口,提示用户输入错误
print(x)
else: #如果程序不存在异常,则执行该程序
print(100 / x)
finally:
print('the program end') #不管程序是否错误,始终都会执行
test(0)
# 0
# the program end
test(1)
# 10.0
# 100.0
# the program end
def test2():
try:
assert False, 'error'
except:
print('another')
# 输出 another
def myLevel(level):
if level < 1:
raise ValueError('Invalid level', level) #自定义异常
try:
myLevel(0)
except ValueError:
print('level < 1')
#输出 :level < 1
print('test 2--')
test2()
2.多进程
引入多进程的库文件: import multiprocessing
多进程测试, 需要在主函数 main 中 进行测试
创建进程的类:Process([group [, target [, name [, args [, kwargs]]]]]),target表示调用对象,args表示调用对象的位置参数元组。kwargs表示调用对象的字典。name为别名。group实质上不使用。
方法:is_alive()、join([timeout])、run()、start()、terminate()。其中,Process以start()启动某个进程。
属性:authkey、daemon(要通过start()设置)、exitcode(进程在运行时为None、如果为–N,表示被信号N结束)、name、pid。其中daemon是父进程终止后自动终止,且自己不能产生新进程,必须在start()之前设置
daemon 是守护进程 :daemon是父进程终止后自动终止,且自己不能产生新进程,必须在start()之前设置。#主线程执行完毕之后,不管子线程是否执行完毕都随着主线程一起结束。
def worker_1():
print('this is worker 1')
time.sleep(3)
print('worker 1 end')
# n = 3
# while n > 0:
# print("The time is {0}".format(time.ctime()))
# time.sleep(interval)
# n -= 1
def worker_2():
print('this is worker 2')
time.sleep(3)
print('worker 2 end')
def worker_3():
print('this is worker 3')
time.sleep(3)
print('worker 3 end')
if __name__ == "__main__":
p1 = multiprocessing.Process(target = worker_1, args = ())
p2 = multiprocessing.Process(target = worker_2, args = ())
p3 = multiprocessing.Process(target = worker_3, args = ())
# p1.daemon = True # 设置子程序为 守护进程, 主程序结束后,它就随之结束(即如果没有join函数,将不执行worker1函数), 需要放在start 前面
p1.start() #进程调用 start 的时候,将自动调用 run 函数
p2.start()
p3.start() #运行3 个worker 程序花费的时间为3 s, 使用了3 个进程进行处理
p1.join()
p2.join()
p3.join() #添加 join 函数, 先执行 worker 函数, 再执行主进程函数
for p in multiprocessing.active_children(): #这是主进程函数
print('name is :' + p.name + 'pid is :' + str(p.pid) +