Python线程,进程,携程,I/O同步,异步
Posted Sargreis
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python线程,进程,携程,I/O同步,异步相关的知识,希望对你有一定的参考价值。
只有本人能看懂的-Python线程,进程,携程,I/O同步,异步
举个栗子:
我想get三个url,先用普通的for循环
import requests
from multiprocessing import Process
from threading import Thread
import requests
import time
# -----正常遍历 串行 同步-----
def get_page(url):
page = requests.get(url)
print(url)
start = time.time()
urls = [‘http://jandan.net/‘,‘https://www.python.org‘,‘http://www.gamersky.com/‘]
for i in urls:
get_page(i)
end = time.time()
print(end - start)
# 这是正常的
这回我用threading模块给他弄快点。
def get_page(url):
page = requests.get(url)
start = time.time()
list = [] # 线程对象列表
urls = [‘http://jandan.net/‘,‘http://www.xiaohuar.com/‘,‘http://www.gamersky.com/‘]
for i in urls:
ok = Thread(target=get_page,args=(i,)) # target为函数名,args为给函数传的参数
list.append(ok)
# get_page(i)
for i in list:
i.start() # 启动一下线程
for i in list:
i.join() # 主线程等待子线程执行之后结束
end = time.time()
print(end - start)
# 开了仨线程运行
# 如果线程使用了join()函数(主线程代码将停在join) ,主进程将等待子线程执行结束再执行
# 如果子线程(ok.setDeamon(True))变成守护线程,那么主线程将不会等待子线程执行结束,当主线程结束时,不管子线程是否执行完毕都将强制终止!
以上是关于Python线程,进程,携程,I/O同步,异步的主要内容,如果未能解决你的问题,请参考以下文章