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

Python多線程原理與用法詳解

 更新時間:2018年08月20日 14:42:33   作者:噴跑的豆子  
這篇文章主要介紹了Python多線程原理與用法,簡單描述了多線程的概念、原理并結(jié)合實例形式分析了Python多線程創(chuàng)建、啟動、各種鎖機制、隊列及相關(guān)函數(shù)使用技巧,需要的朋友可以參考下

本文實例講述了Python多線程原理與用法。分享給大家供大家參考,具體如下:

多線程(英語:multithreading),是指從軟件或者硬件上實現(xiàn)多個線程并發(fā)執(zhí)行的技術(shù)。具有多線程能力的計算機因有硬件支持而能夠在同一時間執(zhí)行多于一個線程,進而提升整體處理性能。具有這種能力的系統(tǒng)包括對稱多處理機、多核心處理器以及芯片級多處理(Chip-level multithreading)或同時多線程(Simultaneous multithreading)處理器。[1] 在一個程序中,這些獨立運行的程序片段叫作“線程”(Thread),利用它編程的概念就叫作“多線程處理(Multithreading)”。具有多線程能力的計算機因有硬件支持而能夠在同一時間執(zhí)行多于一個線程(臺灣譯作“執(zhí)行緒”),進而提升整體處理性能。

創(chuàng)建并啟動一個線程

import threading
def runtask(name):
  print("%s線程已啟動"%name)
t = threading.Thread(target=runtask,args=("task1",))  # args因為是一個元組,所以必須這樣寫,否則運行將報錯
t.start()

join

等待當(dāng)前線程執(zhí)行完畢

import threading
import time
def runtask(name):
  print("%s線程已啟動"%name)
  time.sleep(2)
t = threading.Thread(target=runtask,args=("task1",))
t.start()
t.join()
print("abc")  # 過了2s才會打印,若無等待將看不到等待2s的效果

setDaemon(True)

將線程設(shè)置為守護線程。若設(shè)置為守護線程,主線程結(jié)束后,子線程也將結(jié)束,并且主線程不會理會子線程是否結(jié)束,主線程不會等待子線程結(jié)束完后才結(jié)束。若沒有設(shè)置為守護線程,主線程會等待子線程結(jié)束后才會結(jié)束。

active_count

程序的線程數(shù)量,數(shù)量=主線程+子線程數(shù)量

Lock(互斥鎖)

Python編程中,引入了對象互斥鎖的概念,來保證共享數(shù)據(jù)操作的完整性。每個對象都對應(yīng)于一個可稱為” 互斥鎖” 的標(biāo)記,這個標(biāo)記用來保證在任一時刻,只能有一個線程訪問該對象。在Python中我們使用threading模塊提供的Lock類。

import threading,time
def runtask(name):
  global count
  time.sleep(1)
  lock.acquire()   # 獲取鎖資源,并返回是否獲取成功
  count+=1
  print(name,count)
  lock.release()   # 釋放資源
count = 0
lock = threading.Lock()   # 互斥鎖
for index in range(50):
  t = threading.Thread(target=runtask,args=("thread%d"%index,))
  t.start()

上面這段代碼如果沒有加上互斥鎖,在Python2.x中執(zhí)行的結(jié)果將會是亂的。在Python3.x中執(zhí)行卻總是正確的,似乎是自動為其加了鎖

RLock(遞歸鎖,可重入鎖)

當(dāng)一個線程中遇到鎖嵌套情況該怎么辦,又會遇到什么情況?

def run1():
  global count1
  lock.acquire()
  count1 += 1
  lock.release()
  return count1
def run2():
  global count2
  lock.acquire()
  count2 += 1
  lock.release()
  return count2
def runtask():
  lock.acquire()
  r1 = run1()
  print("="*30)
  r2 = run2()
  lock.release()
  print(r1,r2)
count1,count2 = 0,0
lock = threading.Lock()
for index in range(50):
  t = threading.Thread(target=runtask,)
  t.start()

這是一個很簡單的線程鎖死案例,程序?qū)⒈豢ㄋ?,停止不動。為了解決這一情況,Python提供了遞歸鎖RLock(可重入鎖)。這個RLock內(nèi)部維護著一個Lock和一個counter變量,counter記錄了acquire的次數(shù),從而使得資源可以被多次require。直到一個線程所有的acquire都被release,其他的線程才能獲得資源。上面的代碼只需做一些小小的改動

lock = threading.Lock()

修改為:

lock = threading.RLock()

那么程序?qū)⒉粫l(fā)生死鎖情況。

最大可執(zhí)行線程

threading.BoundedSemaphore(5)設(shè)置可同時執(zhí)行的最大線程數(shù)為5個,后面的線程需排隊等待前面的線程執(zhí)行完畢

import time,threading
def runtask(name):
  global num
  semaphore.acquire()
  time.sleep(1)
  num += 1
  semaphore.release()
  print(name,num)
num = 0
semaphore = threading.BoundedSemaphore(5)
for index in range(50):
  t = threading.Thread(target=runtask,args=("線程%s"%index,))
  t.start()

執(zhí)行效果:

可以看出上面的程序是每次只有5個線程在同時運行,其他線程需等待前面的線程執(zhí)行完畢,這就是最大可執(zhí)行線程。

Event

Python提供了Event對象用于線程間通信,它是由線程設(shè)置的信號標(biāo)志,如果信號標(biāo)志位為假,則線程等待直到信號被其他線程設(shè)置成真。Event中提供了四個重要的方法來滿足基本的需求。

  • - clear:清除標(biāo)記
  • - set:設(shè)置標(biāo)記
  • - is_set:是否被標(biāo)記
  • - wait:等待被標(biāo)記

代碼示例:

import threading,time
def lighter():
  num = 0
  event.set()   # 設(shè)置標(biāo)記
  while True:
    if num >= 5 and num < 10:
      event.clear()  # 清除標(biāo)記
      print("紅燈亮起,車輛禁止通行")
    if num >= 10:
      event.set()   # 設(shè)置標(biāo)記
      print("綠燈亮起,車輛可以通行")
      num = 0
    num += 1
    time.sleep(1)
def car():
  while True:
    if event.is_set():
      print("車輛正在跑...")
    else:
      print("車輛停下了")
      event.wait()
    time.sleep(1)
event = threading.Event()
t1 = threading.Thread(target=lighter,)
t2 = threading.Thread(target=car,)
t1.start()
t2.start()

這是一個簡單的紅燈停綠燈行案例。初始設(shè)置為綠燈并標(biāo)記,車輛看到標(biāo)記后通行,當(dāng)紅燈亮起的時候取消標(biāo)記,車輛看到?jīng)]有標(biāo)記時停下,等待標(biāo)記。

Queue隊列

使任務(wù)按照某一種特定順序有條不紊的進行。下面介紹幾種常用的隊列:

  • - queue.Queue():先進先出
  • - queue.LifoQueue():先進后出
  • - queue.PriorityQueue:優(yōu)先級隊列,優(yōu)先級的值越小,越先執(zhí)行

下面介紹幾種常用的方法:

  • - get():獲取item,如果隊列已經(jīng)取空將會卡住??稍O(shè)置timeout參數(shù),給定一個超時的值,或者設(shè)置參數(shù)block=False,隊列空直接拋異常
  • - get_nowait():b獲取item。如果隊列取空了,將會直接拋異常
  • - put():放入隊列
  • - empty():隊列是否為空
  • - qsize():獲取隊列的item數(shù)量

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python進程與線程操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》、《Python+MySQL數(shù)據(jù)庫程序設(shè)計入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家Python程序設(shè)計有所幫助。

相關(guān)文章

  • keras slice layer 層實現(xiàn)方式

    keras slice layer 層實現(xiàn)方式

    這篇文章主要介紹了keras slice layer 層實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • 使用Pytorch來擬合函數(shù)方式

    使用Pytorch來擬合函數(shù)方式

    今天小編就為大家分享一篇使用Pytorch來擬合函數(shù)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python CVXOPT模塊安裝及使用解析

    Python CVXOPT模塊安裝及使用解析

    這篇文章主要介紹了Python CVXOPT模塊安裝及使用解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • python實現(xiàn)csv格式文件轉(zhuǎn)為asc格式文件的方法

    python實現(xiàn)csv格式文件轉(zhuǎn)為asc格式文件的方法

    下面小編就為大家分享一篇python實現(xiàn)csv格式文件轉(zhuǎn)為asc格式文件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法

    python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法

    今天小編就為大家分享一篇python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • 基于Python實現(xiàn)wifi連接小程序

    基于Python實現(xiàn)wifi連接小程序

    這篇文章主要為大家詳細(xì)介紹了如何使用Python編程語言編寫一個簡單的連接Wi-Fi的程序,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • 關(guān)于python的mmh3庫安裝以及使用詳解

    關(guān)于python的mmh3庫安裝以及使用詳解

    這篇文章主要介紹了關(guān)于python的mmh3庫安裝以及使用詳解,哈希方法主要有MD、SHA、Murmur、CityHash、MAC等幾種方法,mmh3全程murmurhash3,是一種非加密的哈希算法,常用于hadoop等分布式存儲情境中,需要的朋友可以參考下
    2023-07-07
  • 對python3 sort sorted 函數(shù)的應(yīng)用詳解

    對python3 sort sorted 函數(shù)的應(yīng)用詳解

    今天小編就為大家分享一篇對python3 sort sorted 函數(shù)的應(yīng)用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Django通過dwebsocket實現(xiàn)websocket的例子

    Django通過dwebsocket實現(xiàn)websocket的例子

    今天小編就為大家分享一篇Django通過dwebsocket實現(xiàn)websocket的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python符號計算之實現(xiàn)函數(shù)極限的方法

    Python符號計算之實現(xiàn)函數(shù)極限的方法

    這篇文章主要介紹了Python符號計算之實現(xiàn)函數(shù)極限的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07

最新評論