南强小屋 Design By 杰米
1.python 中创建进程的两种方式:
from multiprocessing import Process import time def test_(): print '-----test-----' if __name__ == '__main__': p = Process(target=test_) p.start() while True: print '--main--' '''1.通过process 类创建一个进程对象,然后start即可开启进程, test test_函数是进程实现的功能''' 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 Pool from time import sleep import 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, Queue import time q = 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 e def test_b(): try: while True: num = q.get_nowait() print '我是进程b 取出数字是:%s'%num time.sleep(1) except Exception, e: print e if __name__ == '__main__': p1 = Process(target=test_a) p2 = Process(target=test_b) p1.start() p2.start()
至此 简单得使用已经结束
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
python,进程,进程池,通信
南强小屋 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
南强小屋 Design By 杰米
暂无python 进程 进程池 进程间通信实现解析的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。