Python 多进程和数据传递的理解
Python 多进程和数据传递的理解 python不仅线程用的是系统原生线程,进程也是用的原生进程 进程的用法和线程大同小异 import multiprocessing p = multiprocessing.Process(target=fun,args=()) 线程的基本方法在进程中都能够使用 但是进程和线程中有一个明显的区别:可以实现多核的运用 python本身会启动一个主进程,并且拥有一个主线程把主进程看做一家之主,那主线程也是他本身,其他线程就相当于老婆们 GIL锁住的,只是一个进程,让一家人团结 但是一个进程只有这么一把全量锁,线程不能单独跑,那就打包一起跑 多进程就这样完成了一般语言中多线程的优化 数据传递 多线程,多进程中总有要协同的工作,都涉及数据的交互,不过交互方式有些不同 信息进行传递的时候,为了不阻塞执行一般会将数据放入对列当中而不是直接返回 线程中,由于都属于同一个进程,定义一个全局的队列在各线程中就能够压入数据 进程可能运行在不同的CPU上,因此,相互间的传递不能在全局定义,只能通过创建时进行传入 内部操作:传入的队列实际上并不是将引用传入,然后直接操作队列,这毕竟是不同的CPU上的工作 队列的传入实际上是队列拷贝的传入,通过pickle拷贝后进行传入,然后再pickle将数据传回 import multiprocessing multiprocessing.Queue() 线程和进程都有不同的队列对象,以实现不同的数据交互,不能错位使用 如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |