Python 线程信号量 semaphore - Python零基础入门教程
目錄
- 一.Python 線程信號量 semaphore 簡介
- 二.Python 線程信號量 semaphore 原理
- 三.Python 線程信號量 semaphore 函數介紹
- 四.Python 線程信號量 semaphore 使用
- 五.猜你喜歡
零基礎 Python 學習路線推薦 : Python 學習目錄 >> Python 基礎入門
一.Python 線程信號量 semaphore 簡介
通過前面對 線程互斥鎖 lock / 線程事件 event / 線程條件變量 condition / 線程定時器 timer 的講解,相信你對線程 threading 模塊已經有了一定的了解,同時執行多個線程的確可以提高程序的效率,但是并非線程的數量越多越好,可能對于計算機而言,你直接運行 20 ~ 30 線程可能沒太大影響,如果同時運行上千個甚至上萬個呢?我相信你電腦會直接癱瘓……
二.Python 線程信號量 semaphore 原理
多線程同時運行,能提高程序的運行效率,但是并非線程越多越好,而 semaphore 信號量可以通過內置計數器來控制同時運行線程的數量,啟動線程**(消耗信號量)內置計數器會自動減一,線程結束(釋放信號量)**內置計數器會自動加一;內置計數器為零,啟動線程會阻塞,直到有本線程結束或者其他線程結束為止;
三.Python 線程信號量 semaphore 函數介紹
- **acquire **— 消耗信號量,內置計數器減一;
- **release **— 釋放信號量,內置計數器加一;
在 semaphore 信號量有一個內置計數器,控制線程的數量,acquire 會消耗信號量,計數器會自動減一;release 會釋放信號量,計數器會自動加一;當計數器為零時,acquire 調用被阻塞,直到 release 釋放信號量為止。
四.Python 線程信號量 semaphore 使用
創建多個線程,限制同一時間最多運行 5 個線程,示例代碼如下:
# !usr/bin/env python # -*- coding:utf-8 _*- """ @Author:猿說編程 @Blog(個人博客地址): www.codersrc.com @File:Python 線程信號量 semaphore.py @Time:2021/05/04 07:37 @Motto:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅持不懈地積累!"""# 導入線程模塊 import threading # 導入時間模塊 import time# 添加一個計數器,最大并發線程數量5(最多同時運行5個線程) semaphore = threading.Semaphore(5)def foo():semaphore.acquire() #計數器獲得鎖time.sleep(2) #程序休眠2秒print("當前時間:",time.ctime()) # 打印當前系統時間semaphore.release() #計數器釋放鎖if __name__ == "__main__":thread_list= list()for i in range(20):t=threading.Thread(target=foo,args=()) #創建線程thread_list.append(t)t.start() #啟動線程for t in thread_list:t.join()print("程序結束!")''' 輸出結果:當前時間: Tue May 4 12:01:43 2021 當前時間: Tue May 4 12:01:43 2021 當前時間: Tue May 4 12:01:43 2021 當前時間: Tue May 4 12:01:43 2021 當前時間: Tue May 4 12:01:43 2021 當前時間: Tue May 4 12:01:45 2021 當前時間: Tue May 4 12:01:45 2021 當前時間: Tue May 4 12:01:45 2021 當前時間: Tue May 4 12:01:45 2021 當前時間: Tue May 4 12:01:45 2021 當前時間: Tue May 4 12:01:47 2021 當前時間: Tue May 4 12:01:47 2021 當前時間: Tue May 4 12:01:47 2021 當前時間: Tue May 4 12:01:47 2021 當前時間: Tue May 4 12:01:47 2021 當前時間: Tue May 4 12:01:49 2021 當前時間: Tue May 4 12:01:49 2021 當前時間: Tue May 4 12:01:49 2021 當前時間: Tue May 4 12:01:49 2021 當前時間: Tue May 4 12:01:49 2021 程序結束!Process finished with exit code 0'''根據打印的日志可以看出,同一時間只有 5 個線程運行,間隔兩秒之后,再次啟動 5 個線程,直到 20 個線程全部運行結束為止;如果沒有設置信號量 Semapaore ,創建線程直接 start ,輸出的時間全部都是一樣的,這個問題比較簡單,可以自己去實驗一下!
五.猜你喜歡
未經允許不得轉載:猿說編程 ? Python 線程信號量 semaphore
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的Python 线程信号量 semaphore - Python零基础入门教程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: BugkuCTF-MISC题宽带信息泄露
- 下一篇: Python frozenset 集合