激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python 多線程抓取圖片效率對比

Python 多線程抓取圖片效率對比

2020-08-13 11:00腳本之家 Python

Python由于有全鎖局的存在,并不能利用多核優勢。所以,如果你的多線程進程是CPU密集型的,那多線程并不能帶來效率上的提升,相反還可能會因為線程的頻繁切換,導致效率下降;如果是IO密集型,多線程進程可以利用IO阻塞等待

目的:

是學習python 多線程的工作原理,及通過抓取400張圖片這種IO密集型應用來查看多線程效率對比

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import requests
import urlparse
import os
import time
import threading
import Queue
 
path = '/home/lidongwei/scrapy/owan_img_urls.txt'
#path = '/home/lidongwei/scrapy/cc.txt'
fetch_img_save_path = '/home/lidongwei/scrapy/owan_imgs/'
 
# 讀取保存再文件里面400個urls
with open(path) as f :
  urls = f.readlines()
 
urls = urls[:400]
# 使用Queue來線程通信,因為隊列是線程安全的(就是默認這個隊列已經有鎖)
q = Queue.Queue()
for url in urls:
  q.put(url)
 
start = time.time()
 
def fetch_img_func(q):
  while True:
    try:
      # 不阻塞的讀取隊列數據
      url = q.get_nowait()
      i = q.qsize()
    except Exception, e:
      print e
      break;
    print 'Current Thread Name Runing %s ... 11' % threading.currentThread().name
    url = url.strip()
    img_path = urlparse.urlparse(url).path
    ext = os.path.splitext(img_path)[1]
    print 'handle %s pic... pic url %s ' % (i, url)
    res = requests.get(url, stream=True)
 
    if res.status_code == 200:
      save_img_path = '%s%s%s' % (fetch_img_save_path, i, ext)
      # 保存下載的圖片
      with open(save_img_path, 'wb') as fs:
        for chunk in res.iter_content(1024):
          fs.write(chunk)
        print 'save %s pic ' % i
 
# 可以開多個線程測試不同效果
t1 = threading.Thread(target=fetch_img_func, args=(q, ), name="child_thread_1")
#t2 = threading.Thread(target=fetch_img_func, args=(q, ), name="child_thread_2")
#t3 = threading.Thread(target=fetch_img_func, args=(q, ), name="child_thread_3")
#t4 = threading.Thread(target=fetch_img_func, args=(q, ), name="child_thread_4")
t1.start()
#t2.start()
#t3.start()
#t4.start()
t1.join()
#t2.join()
#t3.join()
#t4.join()
 
end = time.time()
print 'Done %s ' % (end-start)

實驗結果

400圖片

?
1
2
3
4
4線程 Done 12.443133831
3線程 Done 12.9201757908
2線程 Done 32.8628299236
1線程 Done 54.6115460396

總結

Python 自帶GIL 大鎖, 沒有真正意義上的多線程并行執行。GIL 大鎖會在線程阻塞的時候釋放,此時等待的線程就可以激活工作,這樣如此類推,大大提高IO阻塞型應用的效率。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 一级毛片免费高清 | 一级做a爰片性色毛片2021 | 在线免费观看日韩视频 | 亚洲最大中文字幕 | hdjapanesemassagehd日本 | 最近中文字幕一区二区 | 91久久国产露脸精品国产护士 | 久久久aa| 久综合| 色偷偷欧美 | 国产二区三区视频 | 亚洲欧美成aⅴ人在线观看 av免费在线播放 | 狠狠久久 | 中文字幕在线免费 | 久草在线视频网 | 亚洲码无人客一区二区三区 | 国内成人自拍视频 | 欧美成人激情 | 日本一道aⅴ不卡免费播放 日日草夜夜操 | 精品一区二区三区中文字幕老牛 | 中文字幕在线看第二 | 亚州精品天堂中文字幕 | 精品国产乱码久久久久久久久 | 一区二区三区视频播放 | 久久精品一区二区三区国产主播 | 羞羞的视频在线免费观看 | 国产精品免费久久久 | 成av人在线观看 | 久久精品国产99久久6动漫亮点 | 久久久精品视频在线观看 | 久久精品免费网站 | 国产二区三区在线播放 | 一级毛片a级 | 欧美成人性生活片 | 免费国产不卡午夜福在线 | 久久亚洲精品11p | 中国av免费在线观看 | av免费在线免费观看 | 久久久久久久久久亚洲精品 | 日本黄色网战 | 免费黄色在线观看网站 |