Python多进程同步Lock、Semaphore、Event实例

作者:junjie 时间:2021-02-22 17:11:26 

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

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

标签:Python,多进程同步,Lock,Semaphore,Event
0
投稿

猜你喜欢

  • Python利用PyExecJS库执行JS函数的案例分析

    2022-10-26 08:53:19
  • Python中的类对象示例详解

    2022-03-20 12:40:50
  • python下10个简单实例代码

    2023-01-31 19:38:20
  • php之redis短线重连案例讲解

    2023-06-12 13:16:04
  • python实现DNS正向查询、反向查询的例子

    2022-10-29 07:18:55
  • Python Pandas数据合并pd.merge用法详解

    2022-07-18 22:15:47
  • OpenCV图像变换之傅里叶变换的一些应用

    2023-12-01 22:11:34
  • Jupyter Notebook的连接密码 token查询方式

    2023-10-21 23:51:47
  • Python基于SMTP协议实现发送邮件功能详解

    2022-07-17 00:31:00
  • 详解Django中CSRF和CORS的区别

    2021-02-19 19:16:51
  • 浏览器tab的设计

    2008-08-11 13:03:00
  • Numpy中创建数组的9种方式小结

    2021-03-25 21:39:43
  • Python绘制K线图之可视化神器pyecharts的使用

    2023-06-28 12:30:58
  • python命令行参数解析OptionParser类用法实例

    2022-06-21 17:57:24
  • Python字典生成式、集合生成式、生成器用法实例分析

    2021-04-06 08:06:31
  • Pytorch平均池化nn.AvgPool2d()使用方法实例

    2023-09-30 02:49:35
  • Python如何快速上手? 快速掌握一门新语言的方法

    2023-05-07 12:00:48
  • 屏蔽Flash 右键菜单的方法

    2008-05-24 07:21:00
  • 页面设计之个性元素与共性元素

    2008-07-17 12:36:00
  • 使用 Python 实现文件递归遍历的三种方式

    2022-08-19 18:49:08
  • asp之家 网络编程 m.aspxhome.com