欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python的線程使用隊列Queue來改造轉(zhuǎn)賬場景

 更新時間:2022年02月24日 11:27:56   作者:雷學(xué)委  
前篇我們了隊列Queue和轉(zhuǎn)賬場景這次趁熱學(xué)委展示一下使用隊列解決轉(zhuǎn)賬場景的問題,這篇文章主要介紹了Python的線程使用隊列來改造轉(zhuǎn)賬場景,需要的朋友可以參考一下

前篇我們了隊列Queue轉(zhuǎn)賬場景這次趁熱學(xué)委展示一下使用隊列解決轉(zhuǎn)賬場景的問題。

一、看看轉(zhuǎn)賬場景的問題

前面有兩篇文章展示了轉(zhuǎn)賬反復(fù)讀寫amount,導(dǎo)致結(jié)果出錯。

xuewei_account = dict()
xuewei_account['amount'] = 100

# amount為負數(shù)即是轉(zhuǎn)出金額
def transfer(money):
? ? for i in range(100000):
? ? ? ? xuewei_account['amount'] = xuewei_account['amount'] + money

我們前幾篇使用多個線程反復(fù)轉(zhuǎn)長:+1和-1。

按常理,結(jié)果應(yīng)該仍舊是100.

這個是全部代碼:

import random
import threading
import datetime
import time

xuewei_account = dict()
xuewei_account['amount'] = 100


# amount為負數(shù)即是轉(zhuǎn)出金額
def transfer(money):
? ? for i in range(100000):
? ? ? ? xuewei_account['amount'] = xuewei_account['amount'] + money


# 創(chuàng)建20個任務(wù)重復(fù)給學(xué)委賬戶轉(zhuǎn)賬
threads = []
for i in range(10):
? ? t1 = threading.Thread(target=lambda: transfer(-1))
? ? threads.append(t1)
? ? t2 = threading.Thread(target=lambda: transfer(1))
? ? threads.append(t2)

for t in threads:
? ? t.start()
for t in threads:
? ? t.join()

print("-" * 16)
print("活躍線程數(shù):", threading.active_count())
print("活躍線程:", threading.current_thread().name)
print("學(xué)委賬戶余額:", xuewei_account)

等待所有轉(zhuǎn)賬線程運行結(jié)束,我們看到結(jié)果是錯誤的:

二、這種問題怎么使用隊列來解決呢?

前面說了,多線程反復(fù)讀寫共享數(shù)據(jù),是問題的根源。

改代碼為同步互斥模式,保證任意一個時間一個線程更新共享數(shù)據(jù),那么問題就解決了。(這前面也展示了,用的是Lock鎖的方案)

這個能怎么用隊列呢?

可以先思考10秒,根據(jù)學(xué)習(xí)到的加鎖和隊列的特性,想想這個怎么做。

好,答案現(xiàn)在揭曉:

Queue這個隊列有多個函數(shù),一個是put函數(shù),一個是get函數(shù)。

一個負責(zé)放入數(shù)據(jù)到隊尾,一個可以從對頭取出元素。

剛好適合轉(zhuǎn)賬業(yè)務(wù),我們是不是可以把每次轉(zhuǎn)賬操作變成一個一個指令/事件。 比如下面的:

event(amount=1,acount=xuewei_account)
....
event(amount=-1,acount=xuewei_account)
....
event(amount=1,acount=xuewei_account)
....
event(amount=-1,acount=xuewei_account)

20個線程,每個10萬次數(shù)據(jù)讀寫,共200萬個事件。

所以我們可以把這個事情轉(zhuǎn)換為:200萬個轉(zhuǎn)賬事件。

因為Queue是線程安全的,所以我們可以并發(fā)200萬次轉(zhuǎn)賬,另外交給一線程進行轉(zhuǎn)賬處理。

這樣就保證每次只有一個線程對xuewei_account學(xué)委賬戶進行讀寫。

改造,使用隊列來解決問題

展示代碼:

import random
import threading
import datetime
import time
import queue

q = queue.Queue()

xuewei_account = dict()
xuewei_account['amount'] = 100


# amount為負數(shù)即是轉(zhuǎn)出金額
def transfer(money):
? ? for i in range(100000):
? ? ? ? q.put(money)


def handle_amount():
? ? while not q.empty():
? ? ? ? amount = q.get()
? ? ? ? xuewei_account['amount'] += amount


def monitor_q():
? ? counter = 0
? ? time.sleep(3)
? ? while counter < 1000 and not q.empty():
? ? ? ? print("q size:", q.qsize())
? ? ? ? time.sleep(3)
? ? ? ? counter+=1


q_thread = threading.Thread(name="Q監(jiān)控", target=monitor_q)
q_thread.start()
# 創(chuàng)建20個任務(wù)重復(fù)給學(xué)委賬戶轉(zhuǎn)賬
threads = []
for i in range(10):
? ? t1 = threading.Thread(target=lambda: transfer(-1))
? ? threads.append(t1)
? ? t2 = threading.Thread(target=lambda: transfer(1))
? ? threads.append(t2)

for t in threads:
? ? t.start()

vip_thread = threading.Thread(name="處理轉(zhuǎn)賬專線", target=handle_amount)
vip_thread.start()

for t in threads:
? ? t.join()
vip_thread.join()

print("-" * 16)
print("活躍線程數(shù):", threading.active_count())
print("活躍線程:", threading.current_thread().name)
print("學(xué)委賬戶余額:", xuewei_account)

這里運行了多個線程執(zhí)行轉(zhuǎn)賬(發(fā)送轉(zhuǎn)賬金額進隊列)。

然后運行一個vip通道(單獨線程)處理學(xué)委賬戶的轉(zhuǎn)賬業(yè)務(wù)。

同時也運行了一個監(jiān)控隊列的線程,每隔一段時間打印隊列的任務(wù)情況。

下面是運行結(jié)果,運行幾次結(jié)果都是正確的。

運行幾次最終賬戶余額都是100, 改造成功。

三、總結(jié)

本篇學(xué)委分享了線程安全的隊列Queue解決并發(fā)轉(zhuǎn)賬問題。

其實代碼還可以再度優(yōu)化的,為了控制篇幅,代碼也不少,希望讀者朋友們能夠先看熟學(xué)會,掌握隊列的使用。

到此這篇關(guān)于Python的線程使用隊列來改造轉(zhuǎn)賬場景的文章就介紹到這了,更多相關(guān)Python使用隊列來改造轉(zhuǎn)賬場景內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python內(nèi)置函數(shù):lambda、map、filter簡單介紹

    python內(nèi)置函數(shù):lambda、map、filter簡單介紹

    Python 內(nèi)置了一些比較特殊且實用的函數(shù),使用這些能使你的代碼簡潔而易讀。下面對python內(nèi)置函數(shù):lambda、map、filter簡單介紹下,需要的朋友參考下吧
    2017-11-11
  • Python+Pygame實現(xiàn)之走四棋兒游戲的實現(xiàn)

    Python+Pygame實現(xiàn)之走四棋兒游戲的實現(xiàn)

    大家以前應(yīng)該都聽說過一個游戲:叫做走四棋兒。直接在家里的水泥地上用燒完的炭火灰畫出幾條線,擺上幾顆石頭子即可。當(dāng)時的火爆程度可謂是達到了一個新的高度。本文將利用Pygame實現(xiàn)這一游戲,需要的可以參考一下
    2022-07-07
  • 將python圖片轉(zhuǎn)為二進制文本的實例

    將python圖片轉(zhuǎn)為二進制文本的實例

    今天小編就為大家分享一篇將python圖片轉(zhuǎn)為二進制文本的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Selenium常見八大定位法總結(jié)

    Selenium常見八大定位法總結(jié)

    自動化最基礎(chǔ)的就屬于定位元素了,元素不會定位,基本上已經(jīng)團滅了,就不用再去考慮什么自動化了,下面這篇文章主要給大家介紹了關(guān)于Selenium常見八大定位法的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • Python爬蟲入門教程01之爬取豆瓣Top電影

    Python爬蟲入門教程01之爬取豆瓣Top電影

    這篇文章主要介紹了Python爬蟲入門教程01:豆瓣Top電影爬取的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • python實現(xiàn)字符串完美拆分split()的方法

    python實現(xiàn)字符串完美拆分split()的方法

    今天小編就為大家分享一篇python實現(xiàn)字符串完美拆分split()的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • python實現(xiàn)3D地圖可視化

    python實現(xiàn)3D地圖可視化

    這篇文章主要為大家詳細介紹了python實現(xiàn)3D地圖可視化,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 解決pycharm運行程序出現(xiàn)卡住scanning files to index索引的問題

    解決pycharm運行程序出現(xiàn)卡住scanning files to index索引的問題

    今天小編就為大家分享一篇解決pycharm運行程序出現(xiàn)卡住scanning files to index索引的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python實現(xiàn)多級目錄壓縮與解壓文件的方法

    Python實現(xiàn)多級目錄壓縮與解壓文件的方法

    這篇文章主要介紹了Python實現(xiàn)多級目錄壓縮與解壓文件的方法,涉及Python針對文件路徑的遍歷、判斷以及文件壓縮、解壓縮等相關(guān)操作技巧,需要的朋友可以參考下
    2018-09-09
  • python讀取excel數(shù)據(jù)并且畫圖的實現(xiàn)示例

    python讀取excel數(shù)據(jù)并且畫圖的實現(xiàn)示例

    這篇文章主要介紹了python讀取excel數(shù)據(jù)并且畫圖的實現(xiàn)示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2021-02-02

最新評論