python鎖機制

来源:https://www.cnblogs.com/thomson-fred/archive/2018/08/21/9514587.html
-Advertisement-
Play Games

python多進程,多線程之鎖機制 鎖添加的原因: 在多進程/多線程同時進入臨界資源區獲取和操作共有資源時,會出現資源的爭奪而出現混亂。為了避免這種混亂現象,python提出了鎖機制 線程鎖/進程鎖的定義和運用: 創建鎖對象: lock = Lock() 鎖對象一旦創建,就可以隨時被進程或者線程調用 ...


python多進程,多線程之鎖機制

鎖添加的原因:

在多進程/多線程同時進入臨界資源區獲取和操作共有資源時,會出現資源的爭奪而出現混亂。為了避免這種混亂現象,python提出了鎖機制

 

線程鎖/進程鎖的定義和運用:

創建鎖對象:

lock = Lock()

鎖對象一旦創建,就可以隨時被進程或者線程調用,並且一次創建鎖只有一把,如果多個資源想同時獲取鎖,必須‘排隊’,等上一個進程/線程釋放了鎖才可以請求獲取鎖

 

上鎖(也叫請求鎖)

lock.acquire()

acquire()是一個阻塞函數。一旦請求獲取鎖成功,就會把下麵將要執行的程式的變數記憶體空間‘鎖住’;而獲取不成功則會一直阻塞在那裡,等待上一個獲得鎖的進程/線程釋放鎖。

 

解鎖

lock.release()

 

 

死鎖:

死鎖的出現有兩種情況

1) 當一個進程或者一個線程一直調用或者占用同一鎖Lock而不釋放資源而導致其他進程/線程無法獲得鎖,就會出現的死鎖狀況,一直阻塞在aquire()處

2) 當有兩個進程同時想獲取兩個鎖的時候(再往上推就是多個進程想獲取多個鎖),由於兩者都是出於競爭關係,誰也不讓誰,誰快誰得手,但電腦中這種競爭關係是很微妙的,時間的差異性很小,於是,就出現了兩者都阻塞在同一個地方,都無法同時獲得兩個鎖或者獲取對方已經獲取的但還沒有釋放的鎖。

 

為瞭解決死鎖的問題,於是python提出了可重入鎖的機制(RLock)

重入鎖定義後,一個進程就可以重覆調用指定次數的一個重入鎖,而不用去跟別的進程一起爭奪其他鎖。

 

重入鎖中內部管理者兩個對象,即Lock對象和鎖的調用次數count

下麵說說RLock到底是怎麼用的

1)RLock的定義

mutexA = mutexB = RLock( )

mutex值可以是多個的,定義了多少個,RLock內部的count就為幾

 

2)RLock的請求

mutexA.acquire()

mutexA.acquire()

 

每申請一次鎖,count就減1,兩次請求過後,count從2減為0

 

因為上面定義的重入鎖的內部個數為2,所以該重入鎖可以被一個進程調用兩次,並且在雖然它內部有多個鎖,但只能由一個進程/線程調用,其他進程/線程不能幹預,只有當這個進程/線程釋放掉所有的重入鎖,count=2時才可以被其他進程/線程調用。

 

3)RLock鎖的釋放

mutexA.release()

mutexB.release()

 

舉例:

from multiprocessing import RLock,Process
from time import ctime,sleep

muxteA = mutexB =RLock()

def fn1():
    muxteA.acquire()
    sleep(1)
    print(ctime(),'進程1獲取A鎖')
    mutexB.acquire()
    sleep(2)
    print(ctime(),'進程1獲取B鎖')
    muxteA.release()
    print('進程1釋放A鎖')
    mutexB.release()
    print('進程1釋放B鎖')

def fn2():
    muxteA.acquire()
    sleep(1)
    print(ctime(),'進程2獲取A鎖')
    mutexB.acquire()
    sleep(1)
    print(ctime(),'進程2獲取B鎖')
    muxteA.release()
    print('進程2釋放A鎖')
    mutexB.release()
    print('進程2釋放B鎖')


p1 = Process(target=fn1)
p2 = Process(target=fn2)
p1.start()
p2.start()

p1.join()
p2.join()

 結果如下:

 

那麼如果我讓進程2先開啟呢?

 

結果如下:

 

顯然,鎖的獲得是誰快誰得手,同時也驗證了我上面描述的,一個進程對一個可重入鎖的請求是排他型的,一旦這個進程請求了一個可重入鎖,那麼其他進程就無法再請求了,直到這個進程釋放了可重入鎖內部的所有鎖。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java 自學之路 前言 從運行第一個程式開始算起,我接觸編程也有三年的時間了。最初是從51單片機入門學習的C語言,班裡面的大佬帶著我一起做小項目,但是因為沒人教,基本靠自學,學得慢,寫的代碼也爛,很沒有章法。後來大三下半學期開始準備考研(從電子跨考電腦),從零開始學習數據結構,這才算是真正地入了 ...
  • 1、IOC&DI概述 IOC(Inversion of Control):其思想是反轉資源獲取的方向。傳統的資源查找方向要求組件向容器發起請求查找資源,作為回應,容器適時的返回資源。 而應用了IOC之後,則是容器主動地將資源推送給它所管理的組件,組件要做的僅是選擇一種合適方式來接受資源。也稱查找的被 ...
  • 《Spring Boot基礎教程》 第1節 工具的安裝和使用 Spring Boot文檔 https://qbgbook.gitbooks.io/spring-boot-reference-guide-zh/content/I.%20Spring%20Boot%20Documentation/ 一、 ...
  • 一.字元格式化輸出 占位符 %s s = string 字元串 %d d = digit 整數 %f f = float 浮點數 ''' ......'''不僅可以表示註釋多行,也可以表示列印多行。 二.str.isdigit()方法 檢查字元串是否只由數字組成 三.for迴圈 簡單的for迴圈,輸 ...
  • 一、前言 最近在做Matalb/Simulink與C/C++的混合編程,主要是完成TCP、UDP、SerialPort等常見通信方式的中間件設計,為Simulink模型提供數據採集及解析模塊。 問題在於沒有搞清楚Simulink中調用C/C++的內在機制,將測試OK的C++程式移植到mex上時,總會 ...
  • 楊輝三角有以下幾個特點 : 每個數等於它上方兩數之和。 每行數字左右對稱,由1開始逐漸變大。 第n行的數字有n項。 第n行數字和為2n-1。 第n行的m個數可表示為 C(n-1,m-1),即為從n-1個不同元素中取m-1個元素的組合數。 第n行的第m個數和第n-m+1個數相等 ,為組合數性質之一。 ...
  • 規則 1. 每次移動一個盤子 2. 任何時候大盤子在下麵,小盤子在上面 方法 假設共n個盤子 當n=1時: 1. 直接把A上的一個盤子移動到C上(A C) 當n=2時: 1. 把小盤子從A放到B上(A B) 這裡開始採用參數,rsc源地址=A,dst目的地址=B 2. 把大盤子從A放到C上( A C ...
  • 應用、藍圖與視圖函數 1. 結構,如圖: 1. Flask最上層是 ,在這個核心對象上可以插入很多藍圖,這個藍圖是不能單獨存在的,必須將app作為插板插入app ,在每一個藍圖上,可以註冊很多靜態文件,視圖函數,模板 ,一個業務模塊可以做為一個藍圖,比如book,之前的book.py 放到了app/ ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...