中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎樣控制python爬蟲多線程同時運行

發布時間:2020-11-25 09:37:47 來源:億速云 閱讀:213 作者:小新 欄目:編程語言

這篇文章主要介紹了怎樣控制python爬蟲多線程同時運行,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

互斥鎖同時只允許一個線程更改數據,而Semaphore是同時允許一定數量的線程更改數據 ,比如廁所有3個坑,那最多只允許3個人上廁所,后面的人只能等里面有人出來了才能再進去。

import threading
import time
 
def run(n, semaphore):
    semaphore.acquire()   #加鎖
    time.sleep(1)
    print("run the thread:%s\n" % n)
    semaphore.release()     #釋放
 
if __name__ == '__main__':
    num = 0
    semaphore = threading.BoundedSemaphore(5)  # 最多允許5個線程同時運行
    for i in range(22):
        t = threading.Thread(target=run, args=("t-%s" % i, semaphore))
        t.start()
    while threading.active_count() != 1:
        pass  # print threading.active_count()
    else:
        print('-----all threads done-----')

拓展互斥鎖:

由于線程之間是進行隨機調度,如果有多個線程同時操作一個對象,如果沒有很好地保護該對象,會造成程序結果的不可預期,我們也稱此為“線程不安全”。

感謝你能夠認真閱讀完這篇文章,希望小編分享怎樣控制python爬蟲多線程同時運行內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临邑县| 永济市| 和硕县| 静乐县| 育儿| 施秉县| 波密县| 华亭县| 丰顺县| 长兴县| 涞水县| 泽库县| 永州市| 特克斯县| 上思县| 沛县| 冷水江市| 高碑店市| 攀枝花市| 丽水市| 五华县| 梁河县| 集贤县| 仙桃市| 康定县| 凯里市| 永善县| 彭泽县| 鹤壁市| 常山县| 榆树市| 沽源县| 镇雄县| 陆丰市| 兴国县| 土默特左旗| 司法| 云龙县| 临朐县| 湖口县| 蒲城县|