深入理解深入理解 Python 中的多线程中的多线程 新手必看新手必看
示例示例1
我们将要请求五个不同的url:
单线程
import time
import urllib2
defget_responses():
urls=[
‘http://www.baidu.com',
‘http://www.amazon.com',
‘http://www.ebay.com',
‘http://www.alibaba.com',
‘//www.jb51.net'
] start=time.time()
forurlinurls:
printurl
resp=urllib2.urlopen(url)
printresp.getcode()
print”Elapsed time: %s”%(time.time()-start)
get_responses()
输出是:
http://www.baidu.com200
http://www.amazon.com200
http://www.ebay.com200
http://www.alibaba.com200
//www.jb51.net200
Elapsed time:3.0814409256
解释:
url顺序的被请求
除非cpu从一个url获得了回应,否则不会去请求下一个url
网络请求会花费较长的时间,所以cpu在等待网络请求的返回时间内一直处于闲置状态。
多线程多线程
import urllib2
import time
from threading import Thread
classGetUrlThread(Thread):
def__init__(self, url):
self.url=url
super(GetUrlThread,self).__init__()
defrun(self):
resp=urllib2.urlopen(self.url)
printself.url, resp.getcode()
defget_responses():
urls=[
‘http://www.baidu.com',
‘http://www.amazon.com',
‘http://www.ebay.com',
‘http://www.alibaba.com',
‘//www.jb51.net'
] start=time.time()
threads=[] forurlinurls:
t=GetUrlThread(url)
threads.append(t)
t.start()
fortinthreads:
t.join()
print”Elapsed time: %s”%(time.time()-start)