python开多少进程合适_python多进程基础

本文详细介绍了Python中的多进程编程,包括最简单的多进程、使用类的形式创建进程、进程池的运用、进程间内存独立的特性、队列、pipe以及value和进程锁的使用。通过实例展示了如何在不同场景下使用多进程,强调了在创建进程时需要注意的事项,以及过多进程可能带来的效率问题。
摘要由CSDN通过智能技术生成

python中的多进程编程方式和多线程非常相似,几乎可以说只是换了一些函数,有了之前讲过的多线程基础,很多地方我就只展示一些代码,在涉及到差别的地方再着重说明。

本文分为如下几个部分事先说明

最简单的多进程

类的形式

进程池

进程之间内存独立

队列

pipe

value

进程锁

事先说明

有两点在写代码时需要注意使用多进程时,最好在文件中编写代码,用cmd来执行,在jupyter经常无法得到想要的结果

创建进程的代码一定要放在if __name__ == '__main__'里面

最简单的多进程

import multiprocessing

import time

def myfun(num):

time.sleep(1)

print(num + 1)

if __name__ == '__main__':

for i in range(5):

p = multiprocessing.Process(target = myfun, args = (i, ))

p.start()

另外,join is_alive daemon name current_process等也都是一样的。

类的形式

import multiprocessing

import requests

from bs4 import BeautifulSoup

class MyProcess(multiprocessing.Process):

def __init__(self, i):

multiprocessing.Process.__init__(self)

self.i = i

def run(self):

url = 'https://movie.douban.com/top250?start={}&filter='.format(self.i*25)

r = requests.get(url)

soup = BeautifulSoup(r.content, 'html.parser')

lis = soup.find('ol', class_='grid_view').find_all('li')

for li in lis:

title = li.find('span', class_="title").text

print(title)

if __name__ == '__main__':

for i in range(10):

p = MyProcess(i)

p.start()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值