- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python多线程同步Lock、RLock、Semaphore、Event实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、多线程同步 。
由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地发挥多核cpu的资源。大部分情况都推荐使用多进程.
python的多线程的同步与其他语言基本相同,主要包含:
Lock & RLock :用来确保多线程多共享资源的访问。 Semaphore : 用来确保一定资源多线程访问时的上限,例如资源池。 Event : 是最简单的线程间通信的方式,一个线程可以发送信号,其他的线程接收到信号后执行操作。 。
2、实例 。
1)Lock & RLock 。
Lock对象的状态可以为locked和unlocked 。
使用acquire()设置为locked状态; 使用release()设置为unlocked状态.
如果当前的状态为unlocked,则acquire()会将状态改为locked然后立即返回。当状态为locked的时候,acquire()将被阻塞直到另一个线程中调用release()来将状态改为unlocked,然后acquire()才可以再次将状态置为locked.
Lock.acquire(blocking=True, timeout=-1),blocking参数表示是否阻塞当前线程等待,timeout表示阻塞时的等待时间 。如果成功地获得lock,则acquire()函数返回True,否则返回False,timeout超时时如果还没有获得lock仍然返回False.
实例:(确保只有一个线程可以访问共享资源) 。
。
结果:
RLock与Lock的区别是:RLock中除了状态locked和unlocked外还记录了当前lock的owner和递归层数,使得RLock可以被同一个线程多次acquire().
2)Semaphore 。
Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1; 调用release() 时内置计数器+1; 计数器不能小于0;当计数器为0时,acquire()将阻塞线程直到其他线程调用release().
实例:(同时只有2个线程可以获得semaphore,即可以限制最大连接数为2):
import threading import time 。
。
semaphore = threading.Semaphore(2) def func(): if semaphore.acquire(): for i in range(5): print (threading.currentThread().getName() + ' get semaphore') semaphore.release() print (threading.currentThread().getName() + ' release semaphore') for i in range(4): t1 = threading.Thread(target=func) t1.start() 。
。
结果:
3) Event 。
Event内部包含了一个标志位,初始的时候为false。 可以使用使用set()来将其设置为true; 或者使用clear()将其从新设置为false; 可以使用is_set()来检查标志位的状态; 另一个最重要的函数就是wait(timeout=None),用来阻塞当前线程,直到event的内部标志位被设置为true或者timeout超时。如果内部标志位为true则wait()函数理解返回.
实例: (线程间相互通信) 。
。
import logging import threading import time 。
。
logging.basicConfig(level=logging.DEBUG, format="(%(threadName)-10s : %(message)s", ) 。
def wait_for_event_timeout(e, t): """Wait t seconds and then timeout""" while not e.isSet(): logging.debug("wait_for_event_timeout starting") event_is_set = e.wait(t) logging.debug("event set: %s" % event_is_set) if event_is_set: logging.debug("processing event") else: logging.debug("doing other work") e = threading.Event() t2 = threading.Thread(name="nonblock", target=wait_for_event_timeout,args=(e, 2)) t2.start() logging.debug("Waiting before calling Event.set()") time.sleep(7) e.set() logging.debug("Event is set") 。
。
运行结果:
3、其他 。
1) 线程局部变量 。
线程局部变量的值是跟线程相关的,区别与全局的变量。使用非常简单如下:
。
2)对Lock,semaphore,condition等使用with关键字代替手动调用acquire()和release().
最后此篇关于Python多线程同步Lock、RLock、Semaphore、Event实例的文章就讲到这里了,如果你想了解更多关于Python多线程同步Lock、RLock、Semaphore、Event实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
请检查我对信号量的理解! 我理解计数信号量和二进制信号量背后的想法。然而,用 signal() 和 wait() 实现的自旋锁和信号量之间的区别对我来说有点混合在一起。 例如,自旋锁基本上有两个值(用
有人问我是否可以使用以下功能: void down(struct semaphore* sem); int down_intterruptible(struct semaphore* sem); 仅来
我创建了一个小型电影租赁模拟程序。它的工作原理如下:- 主线程让用户输入客户姓名 每个输入的客户都会启动一个新线程(Customer Runnable) 创建 5 个客户后,租赁服务开始(正在等待 5
我被要求编写测试用例来实际展示信号量和读写信号量在读者多而写者少的情况下的性能,反之亦然。我已经实现了信号量(在内核空间中我们实际上被问到)但不知道如何编写用例并对其进行现场实际评估(明确地)。 最佳
在 Java java.util.concurrent.Semaphore 文档中,我不太清楚如果 semaphore.acquire() 阻塞线程并随后被 InterruptedException
信号量是满足有限等待还是只是为了提供互斥? 最佳答案 答案 正如您将在下面看到的那样,理论上它可能会打破有界等待条件。实际上,它在很大程度上取决于使用哪种调度算法。 wait()的经典实现和 sign
我唯一理解的是 信号量是一种原始方式 关键区域有一个 GUARD 变量(信号量也有,但名称不是 GUARD!) ?? 那么有什么区别呢? 最佳答案 通常,临界区域是一个地方,如果存在两个单独的执行线程
我们有 3 个任务以不同的优先级运行:A (120)、B (110)、C (100)。A 采用带有反转安全标志的互斥信号量。任务 B 执行 semTake,这导致任务 A 的优先级提升到 110。随后
尝试构建我的 React 应用程序,但遇到此编译错误: /Users/jimvercoelen/Documents/bitbucket/inboundmuse-client/node_modules/
似乎 glib 提供互斥体和条件作为线程同步原语,但通用 semaphores 怎么样? (从某种意义上说,它们支持原始的 P 和 V 操作?)我对 GCond 的理解是否正确?相当于一个二进制信号量
我们有 3 个任务以不同的优先级运行:A (120)、B (110)、C (100)。A 采用带有反转安全标志的互斥信号量。任务 B 执行 semTake,这导致任务 A 的优先级提升到 110。随后
一般情况下如何用信号量来描述八个进程的同步上面的优先图? 最佳答案 p1 p2 p3 p4 p5 p6 p7
我正在阅读“操作系统概念”中有关信号量的内容(对于那些了解它的人),并且我认为我完全理解了信号量,直到我阅读了这段话: The critical aspect of semaphores is tha
JUC同步锁原理源码解析四----Semaphore Semaphore 1.Semaphore的来源
Semaphore 是什么 Semaphore 通常我们叫它信号量, 可以用来控制同时访问特定资源的线程数量,通过协调各个线程,以保证合理的使用资源。 可以把它简单的理解成我们停车场入口立着的那个显示
如何在第一次测试失败时中断所有 Cypress 测试? 我们正在使用 semaphore 为每个 PR 使用 Cypress 启动完整的 e2e 测试。但这需要太多时间。 我想在第一次测试失败时中断所
有人知道为什么将信号量操作称为P和V吗?每次阅读有关信号量的章节时,都会显示如下内容: 为了使线程获得资源,它执行P操作。为了使线程释放资源,它执行V操作。 P和V代表什么?为什么它们不被称为等待和信
我正在尝试在python中使用信号量,但无法使其按我想要的方式工作。 我有以下代码: import os import threading import time sem = threading.Se
有什么办法可以找到吗 有多少线程在等待信号量? 当前有多少线程占用了信号量? 如果我使用线程池线程等待信号量,如何让主线程等待线程池线程完成。 谢谢。 最佳答案 这是线程同步中的禁忌知识。因为完全不可
我们可以通过 availablePermits() 获得剩余许可 如何在运行时获取 usedPermits() 或 maxPermits(例如,最大许可从 db 加载并且 db 值可能在信号量创建后发
我是一名优秀的程序员,十分优秀!