參考鏈接: 示例說明Python2.x和Python3.x之間的重要區別
信號量semaphore 是一個變量,控制著對公共資源或者臨界區的訪問。信號量維護著一個計數器,指定可同時訪問資源或者進入臨界區的線程數。下面這篇文章主要給大家介紹了關于Python3.X 線程中信號量的使用方法,需要的朋友可以參考借鑒,下面來一起看看吧。 前言?
最近在學習python,發現了解線程信號量的基礎知識,對深入理解python的線程會大有幫助。所以本文將給大家介紹Python3.X線程中信號量的使用方法,下面話不多說,來一起看看詳細的介紹:?
方法示例?
線程中,信號量主要是用來維持有限的資源,使得在一定時間使用該資源的線程只有指定的數量?
# -*- coding:utf-8 -*-
""" Created by FizLin on 2017/07/23/-下午10:59
?mail: https://github.com/Fiz1994
?信號量
?
?maxconnections = 5
...
pool_sema = BoundedSemaphore(value=maxconnections)
Once spawned, worker threads call the semaphore's acquire and release methods when they need to connect to the server:
?
pool_sema.acquire()
conn = connectdb()
... use connection ...
conn.close()
pool_sema.release()
?
?
"""
import threading
import time
import random
?
sites = ["https://www.baidu.com/", "https://github.com/Fiz1994", "https://stackoverflow.com/",
? ?"https://www.sogou.com/",
? ?"http://english.sogou.com/?b_o_e=1&ie=utf8&fr=common_index_nav&query="] * 20
sites_index = 0
maxconnections = 2
pool_sema = threading.BoundedSemaphore(value=maxconnections)
?
?
def test():
?with pool_sema:
? global sites_index, sites
? url = str(sites[sites_index])
? k = random.randint(10, 20)
? print("爬去: " + url + " 需要時間 : " + str(k))
? sites_index += 1
? # print(url)
? time.sleep(k)
? print('退出 ', url)
?
?
for i in range(100):
?threading.Thread(target=test).start()
?
可以發現該程序中,永遠只有2個爬蟲是處于活動狀態 推薦我們的python學習基地,看老程序是如何學習的!從基礎的python腳本、爬蟲、django、數據挖掘等編程技術,工作經驗,還有前輩精心為學習python的小伙伴整理零基礎到項目實戰的資料,!每天都有程序員定時講解Python技術,分享一些學習的方法和需要留意的小細節 總結?
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助