网络编程
位置:首页>> 网络编程>> Python编程>> python多进程并行代码实例

python多进程并行代码实例

作者:科技改变未来☆  发布时间:2023-04-02 03:09:00 

标签:python,多,进程,并行

这篇文章主要介绍了python多进程并行代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

代码:


from multiprocessing import Process
import sys, os
import time

def timetask(string):
while True:
 print(string)

def works(func, arg, worknum):
proc_record = []
for i in range(worknum):
 p = Process(target = func, args = (i,))
 p.start()
 proc_record.append(p)
for p in proc_record:
 p.join()

if __name__ == '__main__':
arg = 5
procs = 4
works(timetask, arg, procs)

效果图【未加锁,会发现数字1没出现,进程间资源抢夺导致】:

python多进程并行代码实例

优化之后效果:

python多进程并行代码实例

代码:


from multiprocessing import Process
import sys, os
import time
from threading import Lock

def timetask(string):
mutex.acquire()
while True:
 print(string)
 if mutex.locked():
  mutex.release()

mutex = Lock()

def works(func, arg, worknum):
proc_record = []
for i in range(worknum):
 p = Process(target = func, args = (i,))
 p.start()
 proc_record.append(p)
for p in proc_record:
 p.join()

if __name__ == '__main__':
arg = 5
procs = 4
works(timetask, arg, procs)

来源:https://www.cnblogs.com/codeDevotee/p/11610759.html

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com