亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中嘗試多線程編程的一個簡明例子

 更新時間:2015年04月07日 15:35:41   投稿:goldensun  
這篇文章主要介紹了Python中嘗試多線程編程的一個簡明例子,由于GIL的存在,Python中的多線程編程一個是熱點和難點問題,需要的朋友可以參考下

綜述
    多線程是程序設計中的一個重要方面,尤其是在服務器Deamon程序方面。無論何種系統,線程調度的開銷都比傳統的進程要快得多。
  Python可以方便地支持多線程??梢钥焖賱?chuàng)建線程、互斥鎖、信號量等等元素,支持線程讀寫同步互斥。美中不足的是,Python的運行在Python 虛擬機上,創(chuàng)建的多線程可能是虛擬的線程,需要由Python虛擬機來輪詢調度,這大大降低了Python多線程的可用性。希望高版本的Python可以 解決這個問題,發(fā)揮多CPU的最大效率。
  網上有些朋友說要獲得真正多CPU的好處,有兩種方法:
  1.可以創(chuàng)建多個進程而不是線程,進程數和cpu一樣多。
  2.使用Jython 或 IronPython,可以得到真正的多線程。
  閑話少說,下面看看Python如何建立線程
  Python線程創(chuàng)建
  使用threading模塊的 Thread類
  類接口如下

復制代碼 代碼如下:
class  Thread( group=None, target=None, name=None, args=(), kwargs={})

 需要關注的參數是target和args. target 是需要子線程運行的目標函數,args是函數的參數,以tuple的形式傳遞。
  以下代碼創(chuàng)建一個指向函數worker 的子線程
復制代碼 代碼如下:
def worker(a_tid,a_account):
     ...
th = threading.Thread(target=worker,args=(i,acc) ) ;

啟動這個線程

復制代碼 代碼如下:
th.start()

等待線程返回
復制代碼 代碼如下:
threading.Thread.join(th)

或者th.join()
如果你可以對要處理的數據進行很好的劃分,而且線程之間無須通信,那么你可以使用:創(chuàng)建=》運行=》回收的方式編寫你的多線程程序。但是如果線程之間需要訪問共同的對象,則需要引入互斥鎖或者信號量對資源進行互斥訪問。
 下面講講如何創(chuàng)建互斥鎖
創(chuàng)建鎖
復制代碼 代碼如下:
g_mutex = threading.Lock()
  ....

使用鎖 
    
復制代碼 代碼如下:
for  ... :
        #鎖定,從下一句代碼到釋放前互斥訪問
        g_mutex.acquire()
        a_account.deposite(1)
        #釋放
        g_mutex.release()

最后,模擬一個公交地鐵IC卡繳車費的多線程程序
  有10個讀卡器,每個讀卡器收費器每次扣除用戶一塊錢進入總賬中,每讀卡器每天一共被刷10000000次。賬戶原有100塊。所以最后的總賬應該為10000100。先不使用互斥鎖來進行鎖定(注釋掉了鎖定代碼),看看后果如何。

import time,datetime
import threading
 
def worker(a_tid,a_account):
 global g_mutex
 print("Str " , a_tid, datetime.datetime.now() )
 for i in range(1000000):
  #g_mutex.acquire()
  a_account.deposite(1)
  #g_mutex.release()
 print("End " , a_tid , datetime.datetime.now() )
  
class Account:
 def __init__ (self, a_base ):
  self.m_amount=a_base
 def deposite(self,a_amount):
  self.m_amount+=a_amount
 def withdraw(self,a_amount):
  self.m_amount-=a_amount 
 
if __name__ == "__main__":
 global g_mutex
 count = 0
 dstart = datetime.datetime.now()
 print("Main Thread Start At: ", dstart)
 #init thread_pool
 thread_pool = []
 #init mutex
 g_mutex = threading.Lock()
 # init thread items
 acc = Account(100)
 for i in range(10):
  th = threading.Thread(target=worker,args=(i,acc) ) ;
  thread_pool.append(th)
   
 # start threads one by one  
 for i in range(10):
  thread_pool[i].start()
  
 #collect all threads
 for i in range(10):
  threading.Thread.join(thread_pool[i])
 dend = datetime.datetime.now()
 print("count=", acc.m_amount)
 print("Main Thread End at: ", dend, " time span ", dend-dstart)

注意,先不用互斥鎖進行臨界段訪問控制,運行結果如下:
201547153033091.png (640×398)

從結果看到,程序確實是多線程運行的。但是由于沒有對對象Account進行互斥訪問,所以結果是錯誤的,只有3434612,比原預計少了很多。

打開鎖后:
201547153202423.png (621×393)

這次可以看到,結果正確了。運行時間比不進行互斥多了很多,不過這也是同步的代價。
同時發(fā)現,寫多線程,多進程類的程序,不能用自帶的idle來運行。會有錯誤。

相關文章

  • 詳解PyQt5 GUI 接收UDP數據并動態(tài)繪圖的過程(多線程間信號傳遞)

    詳解PyQt5 GUI 接收UDP數據并動態(tài)繪圖的過程(多線程間信號傳遞)

    這篇文章主要介紹了PyQt5 GUI 接收UDP數據并動態(tài)繪圖(多線程間信號傳遞),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • python中adb有什么功能

    python中adb有什么功能

    在本篇文章里小編給大家分享的是關于python中adb有功能的知識點總結,有需要的可以跟著學習下。
    2020-06-06
  • Pycharm中import torch報錯的快速解決方法

    Pycharm中import torch報錯的快速解決方法

    這篇文章主要介紹了Pycharm中import torch報錯的快速解決方法,很多朋友容易碰到這個問題,今天小編特此把解決方案分享到腳本之家平臺供大家參考,需要的朋友可以參考下
    2020-03-03
  • 關于pyqt5彈出提示框的詳細介紹

    關于pyqt5彈出提示框的詳細介紹

    在實際的程序開發(fā)中經常會用到各種各樣的消息框來給用戶一些提示或提醒,下面這篇文章主要給大家介紹了關于pyqt5彈出提示框的詳細介紹,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • Python 函數繪圖及函數圖像微分與積分

    Python 函數繪圖及函數圖像微分與積分

    今天小編就為大家分享一篇Python 函數繪圖及函數圖像微分與積分,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Keras預訓練的ImageNet模型實現分類操作

    Keras預訓練的ImageNet模型實現分類操作

    這篇文章主要介紹了Keras預訓練的ImageNet模型實現分類操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • flask設置cookie

    flask設置cookie

    這篇文章主要介紹了flask設置cookie,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,感興趣的同學可以參考閱讀
    2023-04-04
  • Django上傳xlsx文件直接轉化為DataFrame或直接保存的方法

    Django上傳xlsx文件直接轉化為DataFrame或直接保存的方法

    這篇文章主要介紹了Django上傳xlsx文件直接轉化為DataFrame或直接保存的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • Python中format()格式輸出全解

    Python中format()格式輸出全解

    這篇文章主要介紹了Python中format()格式輸出 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • 深入詳解Python中生成器的原理與應用

    深入詳解Python中生成器的原理與應用

    生成器 是Python中一種非常實用的特性,它能幫助我們編寫高效的代碼,本文將詳細為大家介紹生成器的原理、用法以及實際應用場景,有需要的小伙伴可以了解下
    2023-12-12

最新評論