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

python并發(fā)編程多進(jìn)程 模擬搶票實(shí)現(xiàn)過程

 更新時(shí)間:2019年08月20日 15:10:21   作者:minger_lcm  
這篇文章主要介紹了python并發(fā)編程多進(jìn)程 模擬搶票實(shí)現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

 搶票是并發(fā)執(zhí)行

多個(gè)進(jìn)程可以訪問同一個(gè)文件

多個(gè)進(jìn)程共享同一文件,我們可以把文件當(dāng)數(shù)據(jù)庫(kù),用多個(gè)進(jìn)程模擬多個(gè)人執(zhí)行搶票任務(wù)

db.txt

{"count": 1}

并發(fā)運(yùn)行,效率高,但競(jìng)爭(zhēng)寫同一文件,數(shù)據(jù)寫入錯(cuò)亂,只有一張票,都賣成功給了10個(gè)人

#文件db.txt的內(nèi)容為:{"count":1}
#注意一定要用雙引號(hào),不然json無法識(shí)別
from multiprocessing import Process
import time
import json
class Foo(object):
  def search(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)
      time.sleep(1) # 模擬讀數(shù)據(jù)的網(wǎng)絡(luò)延遲
      print("<%s>用戶 查看剩余票數(shù)為 [%s]" % (name, dic["count"]))
  def get(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)
      if dic["count"] > 0:
        dic["count"] -= 1
        time.sleep(1) # 模擬寫數(shù)據(jù)的網(wǎng)絡(luò)延遲
        with open("db.txt", "w") as f_write:
          json.dump(dic, f_write)
          print("<%s> 購(gòu)票成功" % name)
          print("剩余票數(shù)為 [%s]" % dic["count"])
      else:
        print("沒票了,搶光了")
  def task(self, name):
    self.search(name)
    self.get(name)
if __name__ == "__main__":
  obj = Foo()
  for i in range(1,11):  # 模擬并發(fā)10個(gè)客戶端搶票
    p = Process(target=obj.task, args=("路人%s" % i,))
    p.start()

總結(jié):程序出現(xiàn)數(shù)據(jù)寫入錯(cuò)亂

大家都查到票為1,都購(gòu)票成功

<路人1>用戶 查看剩余票數(shù)為 [1]
<路人2>用戶 查看剩余票數(shù)為 [1]
<路人3>用戶 查看剩余票數(shù)為 [1]
<路人4>用戶 查看剩余票數(shù)為 [1]
<路人5>用戶 查看剩余票數(shù)為 [1]
<路人6>用戶 查看剩余票數(shù)為 [1]
<路人7>用戶 查看剩余票數(shù)為 [1]
<路人8>用戶 查看剩余票數(shù)為 [1]
<路人9>用戶 查看剩余票數(shù)為 [1]
<路人10>用戶 查看剩余票數(shù)為 [1]
<路人1> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人2> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人3> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人4> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人5> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人6> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人7> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人8> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人9> 購(gòu)票成功
剩余票數(shù)為 [0]
<路人10> 購(gòu)票成功
剩余票數(shù)為 [0]

總結(jié)程序出現(xiàn)數(shù)據(jù)寫入錯(cuò)亂

加鎖處理:購(gòu)票行為由并發(fā)變成了串行,犧牲了運(yùn)行效率,但保證了數(shù)據(jù)安全

購(gòu)票功能不應(yīng)該并發(fā)執(zhí)行,查票應(yīng)該是并發(fā)執(zhí)行的

查票準(zhǔn)不準(zhǔn)確不重要,有可能這張票就被別人買走

一個(gè)人寫完以后,讓另外一個(gè)人基于上一個(gè)人寫的結(jié)果,再做購(gòu)票操作

#把文件db.txt的內(nèi)容重置為:{"count":1}
from multiprocessing import Process
from multiprocessing import Lock
import time
import json
class Foo(object):
  def search(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)
      time.sleep(1) # 模擬讀數(shù)據(jù)的網(wǎng)絡(luò)延遲
      print("<%s>用戶 查看剩余票數(shù)為 [%s]" % (name, dic["count"]))
  def get(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)
      if dic["count"] > 0:
        dic["count"] -= 1
        time.sleep(1) # 模擬寫數(shù)據(jù)的網(wǎng)絡(luò)延遲
        with open("db.txt", "w") as f_write:
          json.dump(dic, f_write)
          print("<%s> 購(gòu)票成功" % name)
          print("剩余票數(shù)為 [%s]" % dic["count"])
      else:
        print("沒票了,搶光了")
  def task(self, name, mutex):
    self.search(name)
    mutex.acquire()
    self.get(name)
    mutex.release()
if __name__ == "__main__":
  mutex = Lock()
  obj = Foo()
  for i in range(1,11): # 模擬并發(fā)10個(gè)客戶端搶票
    p = Process(target=obj.task, args=("路人%s" % i, mutex))
    p.start()

執(zhí)行結(jié)果

<路人2>用戶 查看剩余票數(shù)為 [1]
<路人3>用戶 查看剩余票數(shù)為 [1]
<路人1>用戶 查看剩余票數(shù)為 [1]
<路人4>用戶 查看剩余票數(shù)為 [1]
<路人5>用戶 查看剩余票數(shù)為 [1]
<路人7>用戶 查看剩余票數(shù)為 [1]
<路人6>用戶 查看剩余票數(shù)為 [1]
<路人8>用戶 查看剩余票數(shù)為 [1]
<路人9>用戶 查看剩余票數(shù)為 [1]
<路人10>用戶 查看剩余票數(shù)為 [1]
<路人2> 購(gòu)票成功
剩余票數(shù)為 [0]
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了
沒票了,搶光了

with lock

相當(dāng)于lock.acquire(),執(zhí)行完自代碼塊自動(dòng)執(zhí)行l(wèi)ock.release()

from multiprocessing import Process
from multiprocessing import Lock
import time
import json
class Foo(object):
  def search(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)

      time.sleep(1) # 模擬讀數(shù)據(jù)的網(wǎng)絡(luò)延遲
      print("<%s>用戶 查看剩余票數(shù)為 [%s]" % (name, dic["count"]))
  def get(self, name):
    with open("db.txt", "r") as f_read:
      dic = json.load(f_read)
      if dic["count"] > 0:
        dic["count"] -= 1
        time.sleep(1) # 模擬寫數(shù)據(jù)的網(wǎng)絡(luò)延遲
        with open("db.txt", "w") as f_write:
          json.dump(dic, f_write)
          print("<%s> 購(gòu)票成功" % name)
          print("剩余票數(shù)為 [%s]" % dic["count"])
      else:
        print("沒票了,搶光了")
  def task(self, name, mutex):
    self.search(name)
    with mutex: # 相當(dāng)于lock.acquire(),執(zhí)行完自代碼塊自動(dòng)執(zhí)行l(wèi)ock.release()
      self.get(name)
if __name__ == "__main__":
  mutex = Lock()
  obj = Foo()
  for i in range(1,11): # 模擬并發(fā)10個(gè)客戶端搶票
    p = Process(target=obj.task, args=("路人%s" % i, mutex))
    p.start()

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python鍵值互換的實(shí)現(xiàn)示例

    Python鍵值互換的實(shí)現(xiàn)示例

    Python鍵值互換是一種對(duì)Python字典類型中鍵值對(duì)進(jìn)行反轉(zhuǎn)的技術(shù),有時(shí)候,我們需要以值作為鍵,以鍵作為值來操作字典,這時(shí)候就需要用到鍵值互換的技術(shù),本文主要介紹了Python鍵值互換的實(shí)現(xiàn)示例,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • pytest官方文檔解讀fixtures的autouse

    pytest官方文檔解讀fixtures的autouse

    這篇文章主要為大家介紹了pytest官方文檔解讀fixtures的autouse,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 用Python制作mini翻譯器的實(shí)現(xiàn)示例

    用Python制作mini翻譯器的實(shí)現(xiàn)示例

    這篇文章主要介紹了用Python制作mini翻譯器的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • python操作SqlServer獲取特定表的所有列名(推薦)

    python操作SqlServer獲取特定表的所有列名(推薦)

    這篇文章主要介紹了python操作SqlServer獲取特定表的所有列名,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • Python自定義元類的實(shí)例講解

    Python自定義元類的實(shí)例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于Python自定義元類的實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-03-03
  • 淺析pandas隨機(jī)排列與隨機(jī)抽樣

    淺析pandas隨機(jī)排列與隨機(jī)抽樣

    這篇文章主要介紹了pandas隨機(jī)排列與隨機(jī)抽樣的相關(guān)資料,幫助大家更好的利用pandas進(jìn)行數(shù)據(jù)分析,感興趣的朋友可以了解下
    2021-01-01
  • Pycharm安裝第三方庫(kù)失敗解決方案

    Pycharm安裝第三方庫(kù)失敗解決方案

    這篇文章主要介紹了Pycharm安裝第三方庫(kù)失敗解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • django 中QuerySet特性功能詳解

    django 中QuerySet特性功能詳解

    這篇文章主要介紹了django 中QuerySet特性功能詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 超詳細(xì)注釋之OpenCV旋轉(zhuǎn)圖像任意角度

    超詳細(xì)注釋之OpenCV旋轉(zhuǎn)圖像任意角度

    這篇文章主要介紹了OpenCV旋轉(zhuǎn)圖像任意角度,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • Tensorflow 實(shí)現(xiàn)分批量讀取數(shù)據(jù)

    Tensorflow 實(shí)現(xiàn)分批量讀取數(shù)據(jù)

    今天小編就為大家分享一篇Tensorflow 實(shí)現(xiàn)分批量讀取數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01

最新評(píng)論