时间:2021-05-22
本文实例讲述了Python实现的多线程同步与互斥锁功能。分享给大家供大家参考,具体如下:
#! /usr/bin/env python#coding=utf-8import threadingimport time'''#1、不加锁num = 0class MyThread(threading.Thread): def run(self): global num time.sleep(1) #一定要sleep!!! num = num + 1 msg = self.name + ' num is ---- ' + str(num) print msgdef test(): for i in range(10): s = MyThread() #实例化一个Thread对象,每个Thread对象代表着一个线程 s.start() #通过start()方法,开始线程活动'''#'''class MyThread(threading.Thread): def run(self): for i in range(3): time.sleep(1) msg = self.name+' @ '+str(i) print msgdef test(): for i in range(5): t = MyThread() t.start()#''''''#2、加锁num = 0 #多个线程共享操作的数据mu = threading.Lock() #创建一个锁class MyThread(threading.Thread): def run(self): global num time.sleep(1) if mu.acquire(True): #获取锁状态,一个线程有锁时,别的线程只能在外面等着 num = num + 1 msg = self.name + ' num is ---- ' + str(num) print msg mu.release() #释放锁def test(): for i in range(10): s = MyThread() s.start()'''if __name__ == '__main__': test()运行结果:
再分别运行注释中的每一部分代码:
1. 不加锁:
2. 加锁:
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python进程与线程操作技巧总结》、《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python可以方便地支持多线程。可以快速创建线程、互斥锁、信号量等等元素,支持线程读写同步互斥。美中不足的是,python的运行在python虚拟机上,创建的
前一篇文章Python:使用threading模块实现多线程编程四[使用Lock互斥锁]我们已经开始涉及到如何使用互斥锁来保护我们的公共资源了,现在考虑下面的情
本文实例讲述了python条件变量之生产者与消费者操作。分享给大家供大家参考,具体如下:互斥锁是最简单的线程同步机制,面对复杂线程同步问题,Python还提供了
一、自旋锁自旋锁是一种基础的同步原语,用于保障对共享数据的互斥访问。与互斥锁的相比,在获取锁失败的时候不会使得线程阻塞而是一直自旋尝试获取锁。当线程等待自旋锁的
起步Python提供的多线程模型中并没有提供读写锁,读写锁相对于单纯的互斥锁,适用性更高,可以多个线程同时占用读模式的读写锁,但是只能一个线程占用写模式的读写锁