下载器和进程池

14 篇文章 0 订阅

下载器
import os
from urllib import request
from multiprocessing import Process
#使用面向对象简单

class Process2(Process):
def init(self,url):
super().init()
self.url=url
def run(self):#Process类中的run函数自动调用
print(‘当前进程’,os.getpid(),end=’’)
print(‘父进程’,os.getppid())
# 文件名将图片保存
# file_name=url.split(’/’)[-1]
# response=request.urlopen(url)#网络请求#响应一个对象#urlopen网页地址网页地址urlopen
# content=response.read()#获取相应的内容
# with open(file_name,‘wb’) as fq:#保存
# fq.write(content)
class Process2(Process):
def init(self,url):
super().init()
self.url=url
def run(self):#
if name==‘main’:
urlList=[
‘http://www.langlang2017.com/img/banner’ + str(1) + ‘.png’,
‘http://www.langlang2017.com/img/banner’ + str(2) + ‘.png’
]
for url in urlList:
p=Process2(url)
p.start()
进程池
from multiprocessing import Process
from multiprocessing import Pool
import os,time,random
def worker(msg):
start=time.time()
print(’%s开始执行’%msg)
time.sleep(random.random())
end=time.time()
print(’%s执行结束,用时%0.2f秒’%(msg,end-start))
if name == ‘main’:
p=Pool(3)
for i in range(10):
p.apply_async(func=worker,args=(i,))
p.close()#关闭进程池
p.join()#阻塞使其完成

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的进程和线程是用来进行并发处理任务的工具。进程是在一个子中放入固定数量的进程,当有任务到达时,就从子中拿一个进程来处理任务,处理完毕后再放回子中等待任务。进程的数量是固定的,因此同一时间最多有固定数量的进程在运行。这样可以避免增加操作系统的调度难度,并节省开闭进程的时间,实现并发效果。 在Python中,可以使用`concurrent.futures`模块中的`ProcessPoolExecutor`类来创建进程。通过实例化`ProcessPoolExecutor`类,可以获得一个指定大小的进程。例如,可以使用以下代码实例化一个进程并指定大小为整数`n`: ``` from concurrent.futures import ProcessPoolExecutor pool = ProcessPoolExecutor(n) ``` 其中`n`是进程的大小,即进程的数量。 线程进程的原理类似,不同之处在于线程是在一个子中放入固定数量的线程来处理任务。线程的使用方式也类似,可以使用`concurrent.futures`模块中的`ThreadPoolExecutor`类来创建线程,并指定大小。线程的使用和进程类似,都是从子中获取线程或进程来处理任务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python--进程与线程](https://blog.csdn.net/weixin_43988680/article/details/124284555)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值