1. 程式人生 > 程式設計 >Python 共享變數加鎖、釋放詳解

Python 共享變數加鎖、釋放詳解

一、共享變數

共享變數:當多個執行緒訪問同一個變數的時候。會產生共享變數的問題。

例子:

import threading
sum = 0
loopSum = 1000000
def myAdd():
  global sum,loopSum
for i in range(1,loopSum):
  sum += 1
def myMinu():
  global sum,loopSum):
  sum -= 1
if __name__ == "__main__":
  print("Dont,{0}".format(sum))
t1 = threading.Thread(target = myAdd,args = ())
t2 = threading.Thread(target = myMinu,args = ())
t1.start()
t2.start()
t1.join()
t2.join()
print("Done,{0}".format(sum))

正如上面的結果可以看出:並不是我們期望的0,而是-286705,這就是因為我們共享變量了,同時對變數進行了操作,程式並不是原子的。

2.解決方案:使用“鎖”,“訊號燈”

(1)鎖lock:是一個標誌,表示一個執行緒在佔用一些資源。

使用方式:先上鎖,然後使用共享資源,放心的使用,最後再釋放鎖,即釋放了這個變數。

鎖哪個:哪個資源需要共享,那麼就鎖誰

import threading
sum = 0
loopSum = 1000000
lock = threading.Lock()
# 先生成一個鎖的例項
def myAdd():
  global sum,loopSum):
  lock.acquire()# 這裡申請了一把鎖
sum += 1
lock.release()# 注意千萬不要忘了釋放鎖
def myMinu():
  global sum,loopSum):
  lock.acquire()
sum -= 1
lock.release()
if __name__ == "__main__":
  print("Done,{0}".format(sum))

正如我們所預料的加減的順序無所謂,但最後是零和遊戲,但是上面的那個例子,都也是加減順序無所謂,但是有一點要知道會存在同時對變數的記憶體使用的情況,這就存在記憶體被錯寫的風險,所以最後結果不對,上面的不是零和遊戲。

(2)執行緒的安全問題:

如果一個資源、變數,他對於多執行緒來講,不用加鎖,也不會引起任何問題,則稱為執行緒安全;執行緒不安全的變數型別:list\set\dict;執行緒安全的變數型別:queue

二、原始碼

d25_1_shared_variable_and_lock.py

https://github.com/ruigege66/Python_learning/blob/master/d25_1_shared_variable_and_lock.py

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。