爬虫总结4

1. 多线程

from threading import Thread

t = Thread(target=func, args=(参数1,))
t.setDaemon(True) # 守护线程
t.start()

class ThreadClass(Thread):
	def run(self): pass
ThreadClass().start()

2. Queue队列

q = Queue()
q.put_nowait(i) 
q.put(i) # q.put(i, Fasle)
q.get_nowait() 
q.get() # q.get(False)
q.qsize() 
q.join()
	# 调用q.join()会阻塞当前线程或进程
	# 直到q的计数为0才停止阻塞
	# 发生put动作并成功,计数+1
	# 调用一次q.task_done(),计数就-1
q.task_done()

3. 多进程

from multiprocessing import Process

p = Process(target=func, args=(参数1,))
p.daemon = True # 设置守护进程
p.start()

class ProcessClass(Process):
	def run(self): pass
ProcessClass().start()

4. 线程池

from multiprocessing.dummy import Pool
pool = Pool(n) # 默认n=os.cpu_count() or 1
pool.apply_async(func, callback=_callback)
pool.close()
# 回调函数_callback中必须接受func函数的返回值作为参数

5. 协程池

import gevent.monkey
gevent.monkey.patch_all() # 打补丁
from gevent.pool import Pool
pool = Pool(n) # 默认是1
pool.apply_async(func, callback=_callback)
# 回调函数_callback中必须接受func函数的返回值作为参数
# 协程池没有close方法
# 主进程要在合适地方sleep,让cpu能够执行协程任务
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值