溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何在python線程中使用threading.Thread()函數(shù)

發(fā)布時間:2021-03-02 16:07:08 來源:億速云 閱讀:283 作者:戴恩恩 欄目:開發(fā)技術(shù)

本文章向大家介紹如何在python線程中使用threading.Thread()函數(shù)的基本知識點總結(jié)和需要注意事項,具有一定的參考價值,需要的朋友可以參考一下。

python可以做什么

Python是一種編程語言,內(nèi)置了許多有效的工具,Python幾乎無所不能,該語言通俗易懂、容易入門、功能強大,在許多領(lǐng)域中都有廣泛的應(yīng)用,例如最熱門的大數(shù)據(jù)分析,人工智能,Web開發(fā)等。

1. 線程的概念:

線程,有時被稱為輕量級進程(Lightweight Process,LWP),是程序執(zhí)行流的最小單元。一個標(biāo)準(zhǔn)的線程由線程ID,當(dāng)前指令指針(PC),寄存器集合和堆棧組成。另外,線程是進程中的一個實體,是被系統(tǒng)獨立調(diào)度和分派的基本單位,線程自己不擁有系統(tǒng)資源,只擁有一點兒在運行中必不可少的資源,但它可與同屬一個進程的其它線程共享進程所擁有的全部資源。

2. threading.thread()的簡單使用

2.1 python的thread模塊是比較底層的模塊,python的threading模塊是對thread做了一些包裝的,可以更加方便的被使用

import threading
import time

def saySorry():
  print("親愛的,我錯了,我能吃飯了嗎?")
  time.sleep(1)

if __name__ == "__main__":
  for i in range(5):
    t = threading.Thread(target=saySorry)
    t.start() #啟動線程,即讓線程開始執(zhí)行

運行結(jié)果:

如何在python線程中使用threading.Thread()函數(shù)

使用說明:

  • 可以明顯看出使用了多線程并發(fā)的操作,花費時間要短很多

  • 當(dāng)調(diào)用start()時,才會真正的創(chuàng)建線程,并且開始執(zhí)行

  • 每個線程都有一個唯一標(biāo)示符,來區(qū)分線程中的主次關(guān)系

  • 主線程:mainThread,Main函數(shù)或者程序主入口,都可以稱為主線程

  • 子線程:Thread-x 使用 threading.Thread() 創(chuàng)建出來的都是子線程

  • 線程數(shù)量:主線程數(shù) + 子線程數(shù)

2.2 主線程會等待所有的子線程結(jié)束后才結(jié)束

import threading
from time import sleep,ctime

def sing():
  for i in range(3):
    print("正在唱歌...%d"%i)
    sleep(1)

def dance():
  for i in range(3):
    print("正在跳舞...%d"%i)
    sleep(1)

if __name__ == '__main__':
  print('---開始---:%s'%ctime())

  t1 = threading.Thread(target=sing)
  t2 = threading.Thread(target=dance)

  t1.start()
  t2.start()

  #sleep(5) # 屏蔽此行代碼,試試看,程序是否會立馬結(jié)束?
  print('---結(jié)束---:%s'%ctime())

如何在python線程中使用threading.Thread()函數(shù)

3.查看線程數(shù)量

import threading
from time import sleep,ctime

def sing():
  for i in range(3):
    print("正在唱歌...%d"%i)
    sleep(1)

def dance():
  for i in range(3):
    print("正在跳舞...%d"%i)
    sleep(1)

if __name__ == '__main__':
  print('---開始---:%s'%ctime())

  t1 = threading.Thread(target=sing)
  t2 = threading.Thread(target=dance)

  t1.start()
  t2.start()

  while True:
    length = len(threading.enumerate())
    print('當(dāng)前運行的線程數(shù)為:%d'%length)
    if length<=1:
      break

    sleep(0.5)

如何在python線程中使用threading.Thread()函數(shù)

4.線程參數(shù)及順序

4.1 傳遞參數(shù)的方法:

  • 使用args 傳遞參數(shù) threading.Thread(target=sing, args=(10, 100, 100))

  • 使用kwargs傳遞參數(shù) threading.Thread(target=sing, kwargs={“a”: 10, “b”:100, “c”: 100})

  • 同時使用 args 和 kwargs 傳遞參數(shù) threading.Thread(target=sing, args=(10, ), kwargs={“b”: 100,“c”: 100})

4.2 線程的執(zhí)行順序

import socket
import threading
import time

def sing():
  for i in range(10):
    print("------------------------------")
    time.sleep(0.5)
    
def dance():
  for i in range(10):
    print("-----")
    time.sleep(0.5)

if __name__ == '__main__':
  # 創(chuàng)建兩個子線程
  t1 = threading.Thread(target=sing)
  t2 = threading.Thread(target=dance)
  # 啟動子線程
  t1.start()
  t2.start()

說明:

從代碼和執(zhí)行結(jié)果我們可以看出,多線程程序的執(zhí)行順序是不確定的。當(dāng)執(zhí)行到sleep語句時,線程將被阻塞(Blocked),到sleep結(jié)束后,線程進入就緒(Runnable)狀態(tài),等待調(diào)度。而線程調(diào)度將自行選擇一個線程執(zhí)行。上面的代碼中只能保證每個線程都運行完整個run函數(shù),但是線程的啟動順序、run函數(shù)中每次循環(huán)的執(zhí)行順序都不能確定。

5. 守護線程

守護線程:如果在程序中將子線程設(shè)置為守護線程,則該子線程會在主線程結(jié)束時自動退出,設(shè)置方式為thread.setDaemon(True),要在thread.start()之前設(shè)置,默認(rèn)是false的,也就是主線程結(jié)束時,子線程依然在執(zhí)行。

5.1 如下代碼,主線程已經(jīng)exit() 【其實并沒有真正結(jié)束】,子線程還在繼續(xù)執(zhí)行

import threading
import time

def test():
  for i in range(10):
    print("test is run:", i)
    time.sleep(1)

if __name__ == '__main__':
  # 創(chuàng)建子線程
  t1 = threading.Thread(target=test)
  # 啟動子線程
  t1.start()
  # 休眠2秒
  time.sleep(2)
  print("我 OVER 了")
  # 退出
  exit()

如何在python線程中使用threading.Thread()函數(shù)

5.2 設(shè)置守護線程

設(shè)置為守護線程(如果主線程結(jié)束了,也隨之結(jié)束)
線程.setDaemon(True)

如何在python線程中使用threading.Thread()函數(shù)

以上就是小編為大家?guī)淼娜绾卧趐ython線程中使用threading.Thread()函數(shù)的全部內(nèi)容了,希望大家多多支持億速云!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI