同步的方法基本与多线程相同。

1) Lock

当多个进程需要访问共享资源的时候,Lock可以用来避免访问的冲突。

import multiprocessing
import sys

def worker_with(lock, f):
    with lock:
        fs = open(f,"a+")
        fs.write('Lock acquired via with\n')
        fs.close()
        
def worker_no_with(lock, f):
    lock.acquire()
    try:
        fs = open(f,"a+")
        fs.write('Lock acquired directly\n')
        fs.close()
    finally:
        lock.release()

if __name__ == "__main__":

f = "file.txt"
  
    lock = multiprocessing.Lock()
    w = multiprocessing.Process(target=worker_with, args=(lock, f))
    nw = multiprocessing.Process(target=worker_no_with, args=(lock, f))

w.start()
    nw.start()

w.join()
    nw.join()

在上面的例子中,如果两个进程没有使用lock来同步,则他们对同一个文件的写操作可能会出现混乱。

2)Semaphore

Semaphore用来控制对共享资源的访问数量,例如池的最大连接数。

import multiprocessing
import time

def worker(s,i):
    s.acquire()
    print(multiprocessing.current_process().name + " acquire")
    time.sleep(i)
    print(multiprocessing.current_process().name + " release")
    s.release()

if __name__ == "__main__":
  
    s = multiprocessing.Semaphore(2)
    for i in range(5):
        p = multiprocessing.Process(target=worker, args=(s,i*2))
        p.start()

上面的实例中使用semaphore限制了最多有2个进程同时执行。

3)Event

Event用来实现进程间同步通信。

import multiprocessing
import time

def wait_for_event(e):
    """Wait for the event to be set before doing anything"""
    print ('wait_for_event: starting')
    e.wait()
    print ('wait_for_event: e.is_set()->' + str(e.is_set()))

def wait_for_event_timeout(e, t):
    """Wait t seconds and then timeout"""
    print ('wait_for_event_timeout: starting')
    e.wait(t)
    print ('wait_for_event_timeout: e.is_set()->' + str(e.is_set()))

if __name__ == '__main__':
    e = multiprocessing.Event()
    w1 = multiprocessing.Process(name='block', 
                                 target=wait_for_event,
                                 args=(e,))
    w1.start()

w2 = multiprocessing.Process(name='non-block', 
                                 target=wait_for_event_timeout, 
                                 args=(e, 2))
    w2.start()

time.sleep(3)
    e.set()
    print ('main: event is set')
    
#the output is:
#wait_for_event_timeout: starting
#wait_for_event: starting
#wait_for_event_timeout: e.is_set()->False
#main: event is set
#wait_for_event: e.is_set()->True

参考:http://www.doughellmann.com/PyMOTW/multiprocessing/communication.html

完!

python类库32[多进程同步Lock+Semaphore+Event]相关推荐

  1. python类库32[多线程同步Lock+RLock+Semaphore+Event]

    2019独角兽企业重金招聘Python工程师标准>>> 一 多线程同步 由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地 ...

  2. python 线程 的类库_python类库32[多线程同步Lock+RLock+Semaphore+Event]

    多线程基础:python类库32[多线程同步] 一 多线程同步 由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地发挥多核cpu的资源.大部 ...

  3. 进程同步控制 Lock Semaphore Event

    一.Lock 当多个进程使用同一份数据资源的时候,就会引发数据安全或顺序混乱问题 加锁可以保证多个进程修改同一块数据时,同一时间只能有一个任务可以进行修改,即串行的修改 lock=Lock() loc ...

  4. 0818Python总结-lock,Semaphore,event,Queue,生产者和消费者模型,JoinableQueue

    一.锁 Lock from multiprocessing import Process,Lock 1.Lock基本用法 上锁和解锁是一对,只上锁不解锁会发生死锁现象(代码阻塞,不往下执行了) 互斥锁 ...

  5. 32 多线程同步值Semaphore(信号量)

    互斥锁是只允许一个线程访问共享数据,而信号量是同时允许一定数量的线程访问共享数据,比如银行柜台有5个窗口,允许同时有5个人办理业务,后面的人只能等待,待柜台有人办理完业务后才可以进行相应的柜台办理. ...

  6. python线程安全的计数器_Python多线程同步Lock、RLock、Semaphore、Event实例

    一.多线程同步 由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地发挥多核cpu的资源.大部分情况都推荐使用多进程. python的多线程的 ...

  7. Python多线程、多进程最全整理

    线程与进程的区别 进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握.关于多进程和多线程,教科书上最经典的一句话是"进程是资源分配的最小单位,线程 ...

  8. 太好了, 终于梳理清楚Python多线程与多进程

    在学习Python的过程中,有接触到多线程编程相关的知识点,先前一直都没有彻底的搞明白.今天准备花一些时间,把里面的细节尽可能的梳理清楚. 线程与进程的区别 进程(process)和线程(thread ...

  9. 一篇文章梳理清楚 Python 多线程与多进程

    在学习Python的过程中,有接触到多线程编程相关的知识点,先前一直都没有彻底的搞明白.今天准备花一些时间,把里面的细节尽可能的梳理清楚. 线程与进程的区别 进程(process)和线程(thread ...

最新文章

  1. 计算机组成原理:输入输出系统
  2. 出现authentication mode=Windows/错误解决办法
  3. [攻防世界 pwn]——level2
  4. android微信支付服务端,Android 微信支付返回-1
  5. Angular6_服务端渲染SSR
  6. sourceforge_SourceForge依旧re憬未来
  7. 【mysql问题】can't connect to mysql server on 'localhost' (10060)
  8. db2 控制台执行创建函数语句_Python函数定义及调用
  9. Mac文件夹图标颜色自定义工具Color Folder
  10. 2.安装 Android SDK
  11. postman post传输中文_Postman:Postman简介、安装、入门使用方法详细攻略
  12. 一个量化交易员的日常:屌丝版VS土豪版
  13. 计算机二级可以用笔记本电脑学吗,计算机二级可以自学好过吗
  14. Warning: [antd: Form.Item] `defaultValue` will not work on controlled Field. You should use `initial
  15. Android UI基础控件
  16. IPv6进阶:IPv6 过渡技术之 NAT64(IPv6 节点主动访问 IPv4 节点-地址池方式)
  17. EXT4 之 Android 文件系统剖析
  18. 领导力:“不懂带团队你就自己累”
  19. C++:用ReadFile函数读文件 (附完整源码)
  20. 计算机窗口的跳转列表,win7[开始]菜单和任务栏最近打开的项目(跳转列表)

热门文章

  1. 数字图像处理技术详解程序_安装地暖施工程序有哪些 安装地暖技术要求是什么【详解】...
  2. 查询字符串位置_带合并单元格的数据查询套路,有用
  3. rbac权限管理5张表_PHP之常用的RBAC权限管理详解
  4. 非root用户挂载NFS
  5. Western Digital使用5400 rpm级硬盘使所有人感到困惑
  6. 【项目管理】项目问题应对思路
  7. Docker中部署Mysql8数据库
  8. Docker中操作镜像和容器的常用命令
  9. 系统架构设计师考试知识点整理-2:进程的状态-三态模型和五态模型
  10. Jquery控制select实现dataTables数据联动刷新