Python線(xiàn)程障礙對(duì)象Barrier原理詳解
python線(xiàn)程Barrier俗稱(chēng)障礙對(duì)象,也稱(chēng)柵欄,也叫屏障。
一.線(xiàn)程障礙對(duì)象Barrier簡(jiǎn)介
# 導(dǎo)入線(xiàn)程模塊 import threading # 障礙對(duì)象barrier barrier = threading.Barrier(parties, action=None, timeout=None)
parties — 線(xiàn)程計(jì)數(shù)器,記錄線(xiàn)程數(shù)量,也稱(chēng)線(xiàn)程障礙數(shù)量;
action — 是一個(gè)可調(diào)用函數(shù),當(dāng)?shù)却木€(xiàn)程到達(dá)了線(xiàn)程障礙數(shù)量parties,其中一個(gè)線(xiàn)程會(huì)首先調(diào)用action 對(duì)應(yīng)函數(shù),之后再執(zhí)行線(xiàn)程自己內(nèi)部的代碼;
timeout — 默認(rèn)的超時(shí)時(shí)間;
二.線(xiàn)程障礙對(duì)象Barrier原理
與之前介紹 互斥鎖Lock/事件Event/定時(shí)器Timer等不同,多線(xiàn)程Barrier會(huì)設(shè)置一個(gè)線(xiàn)程障礙數(shù)量parties,如果等待的線(xiàn)程數(shù)量沒(méi)有達(dá)到障礙數(shù)量parties,所有線(xiàn)程會(huì)處于阻塞狀態(tài),當(dāng)?shù)却木€(xiàn)程到達(dá)了這個(gè)數(shù)量就會(huì)喚醒所有的等待線(xiàn)程。
可能說(shuō)的有點(diǎn)抽象,以播放器為例子:首先一個(gè)線(xiàn)程做播放器初始化工作(加載本地文件或者獲取播放地址),然后一個(gè)線(xiàn)程獲取視頻畫(huà)面,一個(gè)線(xiàn)程獲取視頻聲音,只有當(dāng)初始化工作完畢,視頻畫(huà)面獲取完畢,視頻聲音獲取完畢,播放器才會(huì)開(kāi)始播放,其中任意一個(gè)線(xiàn)程沒(méi)有完成,播放器會(huì)處于阻塞狀態(tài)直到三個(gè)任務(wù)都完成!
三.多線(xiàn)程障礙對(duì)象Barrier相關(guān)函數(shù)介紹
wait(timeout=None) — 阻塞并嘗試通過(guò)障礙,如果等待的線(xiàn)程數(shù)量大于或者等于線(xiàn)程障礙數(shù)量parties,則表示障礙通過(guò),執(zhí)行action 對(duì)應(yīng)函數(shù)并執(zhí)行線(xiàn)程內(nèi)部代碼,反之則繼續(xù)等待;如果wait(timeout=None) 等待超時(shí),障礙將進(jìn)入斷開(kāi)狀態(tài)!如果在線(xiàn)程等待期間障礙斷開(kāi)或重置,此方法會(huì)引發(fā)BrokenBarrierError錯(cuò)誤,注意添加異常處理,演示代碼查看案例一;
reset() — 重置線(xiàn)程障礙數(shù)量,返回默認(rèn)的空狀態(tài),即當(dāng)前阻塞的線(xiàn)程重新來(lái)過(guò),如果在線(xiàn)程等待期間障礙斷開(kāi)或重置,此方法會(huì)引發(fā)BrokenBarrierError錯(cuò)誤,注意添加異常處理,演示代碼查看案例二;
四.線(xiàn)程障礙對(duì)象Barrier使用
1.案例一:常規(guī)使用
# !usr/bin/env python
# -*- coding:utf-8 _*-
"""
@Author:何以解憂(yōu)
@Blog(個(gè)人博客地址): shuopython.com
@WeChat Official Account(微信公眾號(hào)):猿說(shuō)python
@Github:www.github.com
@File:python_arbrier.py
@Time:2019/10/31 21:25
@Motto:不積跬步無(wú)以至千里,不積小流無(wú)以成江海,程序人生的精彩需要堅(jiān)持不懈地積累!
"""
# 導(dǎo)入線(xiàn)程模塊
import threading
def plyer_display():
print('初始化通過(guò)完成,音視頻同步完成,可以開(kāi)始播放....')
# 設(shè)置3個(gè)障礙對(duì)象
barrier = threading.Barrier(3, action=plyer_display, timeout=None)
def player_init(statu):
print(statu)
try:
# 設(shè)置超時(shí)時(shí)間,如果2秒內(nèi),沒(méi)有達(dá)到障礙線(xiàn)程數(shù)量,
# 會(huì)進(jìn)入斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤
barrier.wait(2)
except Exception as e: # 斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤
print("等待超時(shí)了... ")
else:
print("xxxooooxxxxxooooxxxoooo")
if __name__ == '__main__':
statu_list = ["init ready","video ready","audio ready"]
thread_list = list()
for i in range(0,3):
t = threading.Thread(target=player_init,args=(statu_list[i],))
t.start()
thread_list.append(t)
for t in thread_list:
t.join()
輸出結(jié)果:
init ready video ready audio ready 初始化通過(guò)完成,音視頻同步完成,可以開(kāi)始播放.... xxxooooxxxxxooooxxxoooo xxxooooxxxxxooooxxxoooo xxxooooxxxxxooooxxxoooo
注意:如果barrier.wait(timeout=None)等待超時(shí),會(huì)進(jìn)入斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤,為了程序的健壯性,最好加上異常處理;
2.案例二:重置線(xiàn)程障礙數(shù)量reset()
# 導(dǎo)入線(xiàn)程模塊
import threading
def plyer_display():
print('初始化通過(guò)完成,音視頻同步完成,可以開(kāi)始播放....')
# 設(shè)置3個(gè)障礙對(duì)象
barrier = threading.Barrier(3, action=plyer_display, timeout=None)
def player_init(statu):
while True:
print(statu)
try:
# 設(shè)置超時(shí)時(shí)間,如果2秒內(nèi),沒(méi)有達(dá)到障礙線(xiàn)程數(shù)量,
# 會(huì)進(jìn)入斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤
barrier.wait(2)
except Exception as e: # 斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤
# print("斷開(kāi)狀態(tài)... ")
continue
else:
print("xxxooyyyxxxooyyyxxxooyyy")
break
if __name__ == '__main__':
statu_list = ["init ready","video ready","audio ready"]
thread_list = list()
for i in range(0,3):
t = threading.Thread(target=player_init,args=(statu_list[i],))
t.start()
thread_list.append(t)
if i == 1: # 重置狀態(tài)
print("不想看愛(ài)情片,我要看愛(ài)情動(dòng)作片....")
barrier.reset()
for t in thread_list:
t.join()
輸出結(jié)果:
init ready video ready 不想看愛(ài)情片,我要看愛(ài)情動(dòng)作片.... init ready video ready audio ready 初始化通過(guò)完成,音視頻同步完成,可以開(kāi)始播放.... xxxooyyyxxxooyyyxxxooyyy xxxooyyyxxxooyyyxxxooyyy xxxooyyyxxxooyyyxxxooyyy
注意:如果barrier.wait(timeout=None)等待超時(shí),會(huì)進(jìn)入斷開(kāi)狀態(tài),引發(fā)BrokenBarrierError錯(cuò)誤,為了程序的健壯性,最好加上異常處理;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java并發(fā)編程:CountDownLatch與CyclicBarrier和Semaphore的實(shí)例詳解
- Java并發(fā)編程(CyclicBarrier)實(shí)例詳解
- Java并發(fā)編程之柵欄(CyclicBarrier)實(shí)例介紹
- Java中CyclicBarrier的用法分析
- python面向?qū)ο蠖嗑€(xiàn)程爬蟲(chóng)爬取搜狐頁(yè)面的實(shí)例代碼
- Python使用面向?qū)ο蠓绞絼?chuàng)建線(xiàn)程實(shí)現(xiàn)12306售票系統(tǒng)
- python 實(shí)現(xiàn)多線(xiàn)程下載視頻的代碼
- python 實(shí)現(xiàn)多線(xiàn)程下載m3u8格式視頻并使用fmmpeg合并
- python子線(xiàn)程退出及線(xiàn)程退出控制的代碼
相關(guān)文章
PyCharm運(yùn)行Python代碼時(shí)出現(xiàn)"未找到模塊"錯(cuò)誤解決步驟
在使用python的過(guò)程中經(jīng)常會(huì)遇到一個(gè)問(wèn)題,就是叫什么名字的模塊未發(fā)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于PyCharm運(yùn)行Python代碼時(shí)出現(xiàn)"未找到模塊"錯(cuò)誤的解決步驟,需要的朋友可以參考下2023-11-11
sklearn-SVC實(shí)現(xiàn)與類(lèi)參數(shù)詳解
今天小編就為大家分享一篇sklearn-SVC實(shí)現(xiàn)與類(lèi)參數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12

