时间:2021-05-22
1.python 中创建进程的两种方式:
from multiprocessing import Processimport timedef test_(): print '-----test-----'if __name__ == '__main__': p = Process(target=test_) p.start() while True: print '--main--' '''1.通过process 类创建一个进程对象,然后start即可开启进程, testtest_函数是进程实现的功能''' from multiprocessing import Process import time class MyNewProcess(Process): def run(self): print '------run-------' if __name__ == '__main__': p = MyNewProcess() p.start() print '---main-----' '''2.通过类似继承process 子类中必须有run 方法 里边实现 进程功能 创建对象之后 调用start'''2.进程池
from multiprocessing import Poolfrom time import sleepimport os def func(num): for i in range(3): print '%s %s' %(os.getpid(),num) # sleep(2)def main(): pool = Pool(3) for i in range(3, 6): res = pool.apply_async(func, (i,)) pool.close() pool.join() if __name__ == '__main__': main()3.进程间通信
'''python 进程间通信 Queue ''''''1.Queue使用方法 1.Queue.qsize(): 返回当前队列包含的消息数量 2.Queue.empty(): 如果队列为空 返回True 反之 False 3.Queue.full(): 如果队列满了返回True 反之 False 4.Queue.get(): 获取队列中一条消息 然后将其从队列中移除 可传参数 超市时长 Queue.get_nowait(): 相当于 Queue.get(False) 取不到值 触发异常 Queue.put(): 将一个值添加到数列 可传参数 超时时长 Queue.put_nowait():相当于 Queue.get(False) 当队列满时 报错'''from multiprocessing import Process, Queueimport timeq = Queue() # 创建队列for i in range(10): q.put(i) def test_a(): try: while True: num = q.get_nowait() print '我是进程a 取出数字为:%s'%num time.sleep(1) except Exception, e: print edef test_b(): try: while True: num = q.get_nowait() print '我是进程b 取出数字是:%s'%num time.sleep(1) except Exception, e: print eif __name__ == '__main__': p1 = Process(target=test_a) p2 = Process(target=test_b) p1.start() p2.start()至此 简单得使用已经结束
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python提供了4种方式来满足进程间的数据通信1.使用multiprocessing.Queue可以在进程间通信,但不能在Pool池创建的进程间进行通信2.使
思路: 队列使用说明: multiprocessing.Queue()#用于进程间通信,单主进程与子进程无法通信(使用进程池时尽量不要使用这个) mu
本文介绍了Android进程间通信实践的示例代码,分享给大家,具体如下:因为线程间的内存是共享的,所以它们之间的通信简单,比如可以通过共享变量等方式实现。而进程
先看看下面的几个方法:star()方法启动进程,join()方法实现进程间的同步,等待所有进程退出。close()用来阻止多余的进程涌入进程池Pool造成进程阻
在初步了解Python多进程之后,我们可以继续探索multiprocessing包中更加高级的工具。这些工具可以让我们更加便利地实现多进程。进程池进程池(Pro