Python的互斥鎖與信號量詳解
并發(fā)與鎖
多個線程共享數(shù)據(jù)的時候,如果數(shù)據(jù)不進行保護,那么可能出現(xiàn)數(shù)據(jù)不一致現(xiàn)象,使用鎖,信號量、條件鎖
互斥鎖
1. 互斥鎖,是使用一把鎖把代碼保護起來,以犧牲性能換取代碼的安全性,那么Rlock后 必須要relase 解鎖 不然將會失去多線程程序的優(yōu)勢
2. 互斥鎖的基本使用規(guī)則:
import threading # 聲明互斥鎖 lock=threading.Rlock(); def handle(sid):# 功能實現(xiàn)代碼 lock.acquire() #加鎖 # writer codeing lock.relase() #釋放鎖
信號量:
1. 調(diào)用relarse()信號量會+1 調(diào)用 acquire() 信號量會-1
可以理解為對于臨界資源的使用,以及進入臨界區(qū)的判斷條件
2. semphore() :當調(diào)用relarse()函數(shù)的時候 單純+1 不會檢查信號量的上限情況。 初始參數(shù)為0
3. boudedsemphore():邊界信號量 當調(diào)用relarse() 會+1 , 并且會檢查信號量的上限情況。不允許超過上限
使用budedsemaphore時候不允許設(shè)置初始為0,將會拋出異常
至少設(shè)置為1 ,如consumer product 時候應(yīng)該在外設(shè)置一個變量,啟動時候?qū)ψ兞孔雠袛?,決定使不使用acquier
4. 信號量的基本使用代碼:
# 聲明信號量:
sema=threading.Semaphore(0); #無上限檢查
sema=threading.BuderedSeamphore(1) #有上限檢查設(shè)置
5
apple=1
def consumner():
seam.acquire(); # ‐1
9
if apple==1:
pass
else: sema2.release();#+ 1
def product():
seam.relarse(); # +1
if apple==1:
pass
else:
print("消費:",apple);
全部的代碼:
# -*- coding: utf-8 -*-
"""
Created on Mon Sep 9 21:49:30 2019
@author: DGW-PC
"""
# 信號量解決生產(chǎn)者消費者問題
import random;
import threading;
import time;
# 聲明信號量
sema=threading.Semaphore(0);# 必須寫參數(shù) 0 表示可以使用數(shù)
sema2=threading.BoundedSemaphore(1);
apple=1;
def product():#生產(chǎn)者
global apple;
apple=random.randint(1,100);
time.sleep(3);
print("生成蘋果:",apple);
#sema2.release(); # +1
if apple==1:
pass
else: sema2.release();#+ 1
def consumer():
print("等待");
sema2.acquire();# -1
if apple==1:
pass
else:
print("消費:",apple);
threads=[];
for i in range(1,3):
t1=threading.Thread(target=consumer);
t2=threading.Thread(target=product);
t1.start();
t2.start();
threads.append(t1);
threads.append(t2);
for x in threads:
x.join();
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python 簡單搭建阻塞式單進程,多進程,多線程服務(wù)的實例
下面小編就為大家?guī)硪黄猵ython 簡單搭建阻塞式單進程,多進程,多線程服務(wù)的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
在Python dataframe中出生日期轉(zhuǎn)化為年齡的實現(xiàn)方法
這篇文章主要介紹了在Python dataframe中出生日期轉(zhuǎn)化為年齡的實現(xiàn)方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10
Python 函數(shù)編編程的三大法寶map+filter+reduce分享
這篇文章主要介紹了Python 函數(shù)編編程的三大法寶map,filter,reduce的分享,python利用 map 在一個可迭代對象的各項上調(diào)用函數(shù)的工具;利用 filter 來過濾項;利用 reduce 把函數(shù)作用在成對的項上來運行結(jié)果的工具,下面我們就來對這三者進行詳細的介紹,需要的朋友可以參考下2022-03-03
Qt6中重大改變的QtMultimedia多媒體模塊實現(xiàn)
本文主要介紹了Qt6中重大改變的QtMultimedia多媒體模塊實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
Python函數(shù)參數(shù)基礎(chǔ)介紹及示例
在聲明函數(shù)的時候,一般會根據(jù)函數(shù)所要實現(xiàn)的功能來決定函數(shù)是否需要參數(shù)。在多數(shù)情況下,我們聲明的函數(shù)都會使用到參數(shù),這篇文章主要介紹了Python函數(shù)參數(shù)2022-08-08

