python 多线程 锁

作者: sunbinqiang | 来源:发表于2016-06-28 13:23 被阅读233次

参考:《Python cookbook》12章

启动和停止线程

start 启动线程;

is_alive 判断是否已经结束;

join 请求连接某个线程, 等待该线程结束,才退出join函数;

daemon参数, 守护线程,该线程无法被连接,主线程结束后自动销毁。(2.7不适用)

终止线程:

需要自己构建终止操作, 一般在while循环中添加标识符来判断是否需要停止线程。

一个demo, 当terminate()后,线程即退出

Event

event 可以实现线程间的通信, 比如这样的情况:线程t1必须在线程t2执行完以后再执行(例如,数据库操作的线程必须等到数据库连接上以后再执行),这时用event可以达到这样的效果

多线程模式下,操作同一数据的时候,需要进行同步控制,否则容易对数据造成破坏。

threading模块提供的Lock类,可以实现某一时刻只有一个线程操作某个数据对象:

```

#创建锁

mutex = threading.Lock()

#锁定

mutex.acquire([timeout])

#释放

mutex.release()

```

其中acquire函数的timeout参数,是指在timeout指定的时间后会通过返回值判断,从而进行一些其他操作。

死锁: 

在上述mutex.acquire()以后,还没有release以前,又进行acquire操作,这时就会出现死锁的情况。在代码逻辑比较复杂的项目中,某一些函数里面很容易出现这样的情况,引发死锁。

threading模块还有另外一个类:Rlock,可重入锁,不会发生死锁的情况,但是要保证一次acquire对应一次release。

另外,可以用语句: with mutex: 代替 mutex.acquire()和mutex.release().

相关文章

  • python多线程

    python基础之多线程锁机制 GIL(全局解释器锁) GIL并不是Python的特性,它是在实现Python解析...

  • Python_提高

    GIL全局解释器锁 描述Python GIL的概念, 以及它对python多线程的影响?编写⼀个 多线程抓取⽹⻚的...

  • 用C语言对Python进行扩展

    python C 扩展代码优点: 可以添加额外的功能:Python的多线程模型受限于GIL锁,自身提供的多线程模型...

  • 09-多进程间的通信与数据共享

    上篇文章对python多线程进行了介绍,GIL锁使得python的多线程并不能并发执行,为了提高多核CPU的利用率...

  • 浅析python的GIL

    Python中的GIL锁 在Python中,可以通过多进程、多线程和多协程来实现多任务。 在多线程的实现过程中,为...

  • 使用Thread进行多线程

    总起:由于python中只有一个线程能拿到GIL(全局锁),因此python的多线程其实是一种伪的多线程。略去其他...

  • Python并发编程

    Python解释器由于设计时有GIL全局锁,导致了多线程无法利用多核。多线程的并发在Python中就是一个美丽的梦...

  • Python day28_GIL 深拷贝浅拷贝

    GIL(全局解释器锁) GIL面试题如下 描述Python GIL的概念, 以及它对python多线程的影响?编写...

  • 通过网络图片小爬虫对比Python中单线程与多线(进)程的效率

    批评 Python 的人通常都会说 Python 的多线程编程太困难了,众所周知的全局解释器锁(Global In...

  • Python进阶10

    多线程 python中的GIL GIL(Global Interpreter Lock),就是一个锁。 Pytho...

网友评论

    本文标题:python 多线程 锁

    本文链接:https://www.haomeiwen.com/subject/vohadttx.html