Python多进程同步Lock、Semaphore、Event实例
同步的方法基本与多线程相同。
1)Lock
当多个进程需要访问共享资源的时候,Lock可以用来避免访问的冲突。
importmultiprocessing importsys
defworker_with(lock,f): withlock: fs=open(f,"a+") fs.write('Lockacquiredviawith\n') fs.close() defworker_no_with(lock,f): lock.acquire() try: fs=open(f,"a+") fs.write('Lockacquireddirectly\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()
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短