Python线程专题8:使用锁的注意事项

上一篇文章: Python线程专题7:条件变量
下一篇文章: Python线程专题9:线程终止与挂起

使用诸如Lock、RLock、Semphore之类的锁原语时,必须多加当心,锁的错误使用很容易致使死锁或相互竞争。依赖锁的代码应该保证当出现异常时能够正常的释放锁。编程

典型代码以下:segmentfault

try:
    lock.acquire()
    #关键部分
    ...
finally:
    lock.release()

另外,全部种类的锁还支持上下文管理协议(写起来更简洁):多线程

with语句自动获取锁,而且在控制流离开上下文时自动释放锁。ui

with lock:
    #关键部分
    ...

此外,编写代码时通常应该避免同时获取多个锁,例以下面就应该尽可能避免:线程

这通知很统一致使应用程序神秘死锁,尽管与集中策略能够避免出现这种状况(如分层锁定),可是最好在编写代码时避免这种嵌套锁。code

with lock_A:
    #关键部分
    ...
    with lock_B:
        #B的关键部分
        ...

尽管在Python中能够使用各类锁和同步原语的组合编写很是传统的多线程程序,但有一种首推的编程方式要优于其余全部编程方式:即将多线程程序组织为多个独立任务的集合,这些任务之间经过消息队列进行通讯,例以下面要讲的queue模块。队列

相关文章
相关标签/搜索