python線程信號量semaphore使用解析
這篇文章主要介紹了python線程信號量semaphore使用解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
一.semaphore信號量原理
多線程同時運(yùn)行,能提高程序的運(yùn)行效率,但是并非線程越多越好,而semaphore信號量可以通過內(nèi)置計數(shù)器來控制同時運(yùn)行線程的數(shù)量,啟動線程(消耗信號量)內(nèi)置計數(shù)器會自動減一,線程結(jié)束(釋放信號量)內(nèi)置計數(shù)器會自動加一;內(nèi)置計數(shù)器為零,啟動線程會阻塞,直到有本線程結(jié)束或者其他線程結(jié)束為止;
二.semaphore信號量相關(guān)函數(shù)介紹
acquire() — 消耗信號量,內(nèi)置計數(shù)器減一;
release() — 釋放信號量,內(nèi)置計數(shù)器加一;
在semaphore信號量有一個內(nèi)置計數(shù)器,控制線程的數(shù)量,acquire()會消耗信號量,計數(shù)器會自動減一;release()會釋放信號量,計數(shù)器會自動加一;當(dāng)計數(shù)器為零時,acquire()調(diào)用被阻塞,直到release()釋放信號量為止。
三.semaphore信號量使用
創(chuàng)建多個線程,限制同一時間最多運(yùn)行5個線程,示例代碼如下:
# !usr/bin/env python # -*- coding:utf-8 _*- """ @Author:何以解憂 @Blog(個人博客地址): shuopython.com @WeChat Official Account(微信公眾號):猿說python @Github:www.github.com @File:python_semaphore.py @Time:2019/10/23 21:25 @Motto:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅持不懈地積累! """ # 導(dǎo)入線程模塊 import threading # 導(dǎo)入時間模塊 import time # 添加一個計數(shù)器,最大并發(fā)線程數(shù)量5(最多同時運(yùn)行5個線程) semaphore = threading.Semaphore(5) def foo(): semaphore.acquire() #計數(shù)器獲得鎖 time.sleep(2) #程序休眠2秒 print("當(dāng)前時間:",time.ctime()) # 打印當(dāng)前系統(tǒng)時間 semaphore.release() #計數(shù)器釋放鎖 if __name__ == "__main__": thread_list= list() for i in range(20): t=threading.Thread(target=foo,args=()) #創(chuàng)建線程 thread_list.append(t) t.start() #啟動線程 for t in thread_list: t.join() print("程序結(jié)束!")
輸出結(jié)果:
當(dāng)前時間: Wed Oct 23 22:21:59 2019 當(dāng)前時間: Wed Oct 23 22:21:59 2019 當(dāng)前時間: Wed Oct 23 22:21:59 2019 當(dāng)前時間: Wed Oct 23 22:21:59 2019 當(dāng)前時間: Wed Oct 23 22:21:59 2019 當(dāng)前時間: Wed Oct 23 22:22:01 2019 當(dāng)前時間: Wed Oct 23 22:22:01 2019 當(dāng)前時間: Wed Oct 23 22:22:01 2019 當(dāng)前時間: Wed Oct 23 22:22:01 2019 當(dāng)前時間: Wed Oct 23 22:22:01 2019 當(dāng)前時間: Wed Oct 23 22:22:03 2019 當(dāng)前時間: Wed Oct 23 22:22:03 2019 當(dāng)前時間: Wed Oct 23 22:22:03 2019 當(dāng)前時間: Wed Oct 23 22:22:03 2019 當(dāng)前時間: Wed Oct 23 22:22:03 2019 當(dāng)前時間: Wed Oct 23 22:22:05 2019 當(dāng)前時間: Wed Oct 23 22:22:05 2019 當(dāng)前時間: Wed Oct 23 22:22:05 2019 當(dāng)前時間: Wed Oct 23 22:22:05 2019 當(dāng)前時間: Wed Oct 23 22:22:05 2019 程序結(jié)束!
根據(jù)打印的日志可以看出,同一時間只有5個線程運(yùn)行,間隔兩秒之后,再次啟動5個線程,直到20個線程全部運(yùn)行結(jié)束為止;如果沒有設(shè)置信號量Semapaore,創(chuàng)建線程直接start(),輸出的時間全部都是一樣的,這個問題比較簡單,可以自己去實驗一下!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python之生產(chǎn)者消費(fèi)者模型實現(xiàn)詳解
- Python之兩種模式的生產(chǎn)者消費(fèi)者模型詳解
- Python自定義進(jìn)程池實例分析【生產(chǎn)者、消費(fèi)者模型問題】
- 理解生產(chǎn)者消費(fèi)者模型及在Python編程中的運(yùn)用實例
- Python 限制線程的最大數(shù)量的方法(Semaphore)
- Python多線程同步Lock、RLock、Semaphore、Event實例
- Python多進(jìn)程同步Lock、Semaphore、Event實例
- Python semaphore evevt生產(chǎn)者消費(fèi)者模型原理解析
相關(guān)文章
python實現(xiàn)在windows服務(wù)中新建進(jìn)程的方法
這篇文章主要介紹了python實現(xiàn)在windows服務(wù)中新建進(jìn)程的方法,涉及Python針對Windows服務(wù)與進(jìn)程操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06windows下cx_Freeze生成Python可執(zhí)行程序的詳細(xì)步驟
這篇文章主要介紹了windows下cx_Freeze生成Python可執(zhí)行程序的詳細(xì)步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10python爬取之json、pickle與shelve庫的深入講解
這篇文章主要給大家介紹了關(guān)于python爬取之json、pickle與shelve庫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03wxpython+pymysql實現(xiàn)用戶登陸功能
這篇文章主要介紹了wxpython+pymysql實現(xiàn)用戶登陸功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11