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

Python中如何創(chuàng)建多線程?

 更新時(shí)間:2023年01月06日 08:37:25   作者:python學(xué)習(xí)者0  
這篇文章主要介紹了Python中如何創(chuàng)建多線程的相關(guān)資料,需要的朋友可以參考下

一、python線程的模塊

1.thread和threading模塊

  • thread模塊提供了基本的線程和鎖的支持
  • threading提供了更高級(jí)別、功能更強(qiáng)的線程管理的功能。

2. Queue模塊

Queue模塊允許用戶創(chuàng)建一個(gè)可以用于多個(gè)線程之間共享數(shù)據(jù)的隊(duì)列數(shù)據(jù)結(jié)構(gòu)。

3.注意模塊的選擇

  • 避免使用thread模塊
  • 因?yàn)楦呒?jí)別的threading模塊更為先進(jìn),對(duì)線程的支持更為完善
  • 而且使用thread模塊里的屬性有可能會(huì)與threading出現(xiàn)沖突;
  • 其次低級(jí)別的thread模塊的同步原語(yǔ)很少(實(shí)際上只有一個(gè)),而threading模塊則有很多;
  • 再者,thread模塊中當(dāng)主線程結(jié)束時(shí),所有的線程都會(huì)被強(qiáng)制結(jié)束掉,沒(méi)有警告也不會(huì)有正常的清除工作,至少threading模塊能確保重要的子線程退出后進(jìn)程才退出。

注意:thread模塊不支持守護(hù)線程,當(dāng)主線程退出時(shí),所有的子線程不論它們是否還在工作,都會(huì)被強(qiáng)行退出。而threading模塊支持守護(hù)線程,守護(hù)線程一般是一個(gè)等待客戶請(qǐng)求的服務(wù)器,如果沒(méi)有客戶提出請(qǐng)求它就在那等著,如果設(shè)定一個(gè)線程為守護(hù)線程,就表示這個(gè)線程是不重要的,在進(jìn)程退出的時(shí)候,不用等待這個(gè)線程退出。

二、Threading模塊

multiprocess模塊的完全模仿了threading模塊的接口,二者在使用層面,有很大的相似性,因而不再詳細(xì)介紹

三、通過(guò)Threading.Thread類(lèi)來(lái)創(chuàng)建線程

1 .創(chuàng)建線程的方式一

直接通過(guò)Threading.Thread來(lái)創(chuàng)建

from threading import Thread
import time

def task(name):
    print(f'子線程{name} is running')
    time.sleep(1)
    print(f'子線程{name} is end')
    
# 因?yàn)閯?chuàng)建線程不需要重新開(kāi)辟內(nèi)存空間,所以不用寫(xiě)main,創(chuàng)建線程只是單獨(dú)把啟動(dòng)線程函數(shù)里面的代碼拿出來(lái)用
t = Thread(target=task,args=('小明',))
t.start()
print('主線程結(jié)束')

2 創(chuàng)建線程的方式二

通過(guò)自定義類(lèi)來(lái)繼承Thread類(lèi)來(lái)創(chuàng)建線程

from threading import Thread
import time

class MyDic(Thread,name):
    def __init__(self,name)
    	super().__init__()
        self.name = name
    
    def run(self):
        print(f'子線程{name} is running')
        time.sleep(1)
        print(f'子線程{name} is end')

       
t = Mydic('小明')
t.start()
print('主進(jìn)程結(jié)束')

四、多線程和多進(jìn)程的比較

1 pid的比較

'''
學(xué)習(xí)中遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書(shū)!
'''
from threading import Thread
from multiprocessing import  Process
import time
import os

def task(name):
    print(f'子線程{name} is running')
    time.sleep(1)
    print(f'子線程{name} is end')
    print(f'子線程{name}的pid:{os.getpid()}')


def task1(name):
    print(f'進(jìn)程{name} is running')
    time.sleep(1)
    print(f'進(jìn)程{name} is end')
    print(f'進(jìn)程的{name}pid:{os.getpid()}')


if __name__ == '__main__':
    # part1:在主進(jìn)程下開(kāi)啟多個(gè)線程,每個(gè)線程都跟主進(jìn)程的pid一樣
    t = Thread(target=task, args=('小明',))
    t.start()
    t.join()
    print(f'主線程的pid:{os.getpid()}')

    
    # 開(kāi)多個(gè)進(jìn)程,每一個(gè)進(jìn)程的pid號(hào)都不一樣
    p = Process(target=task1,args=('zhangsan',))
    p1 = Process(target=task1,args=('zhang',))
    p.start()
    p1.start()
    p.join()
    p1.join()
    print(f'主進(jìn)程的pid:{os.getpid()}')

2 線程和進(jìn)程開(kāi)啟效率的較量

from threading import Thread
from multiprocessing import Process
import time

def task(name):
    print(f'{name} is running')
    time.sleep(2)
    print(f'{name} is end')


if __name__ == '__main__':
    t = Thread(target=task,args=('子線程',))
    p = Process(target=task,args=('子進(jìn)程',))
    t.start()
    # p.start()
    print('主')

(1.開(kāi)啟線程的速度:

子線程 is running

主

子線程 is end

(2.開(kāi)啟進(jìn)程的速度:

主

子進(jìn)程 is running

子進(jìn)程 is end

3 內(nèi)存數(shù)據(jù)共享問(wèn)題

from threading  import Thread
from multiprocessing import  Process
import time,os

x = 100
def task():
    global x
    x = 50 # 此時(shí)線程是在拿全局的x的值
    print(os.getpid()) # 因?yàn)殚_(kāi)啟線程是不需要操作系統(tǒng)給線程分配內(nèi)存空間的,所以線程用的是它當(dāng)前所在的進(jìn)程的進(jìn)程號(hào)


if __name__ == '__main__':
    # 線程
    t = Thread(target=task)
    t.start()
    time.sleep(2)
    print(x) # 50,這里說(shuō)明線程他是共享他所在進(jìn)程下的所有資源,對(duì)資源進(jìn)行一系列的操作
    print(os.getpid())

    # 進(jìn)程
   # p = Process(target=task)
   # p.start() 
   # print(x) # 這里的x還是主進(jìn)程的x 100

五、Thread類(lèi)的其他方法

Thread實(shí)例對(duì)象的方法:

  • isAlive():返回線程是否活動(dòng)的。
  • getName():返回線程名。
  • setName():設(shè)置線程名。

threading模塊提供的一些方法:

  • threading.currentThread():返回當(dāng)前的線程變量。
  • threading.enumerate():返回一個(gè)包含正在運(yùn)行的線程的list。正在運(yùn)行指線程啟動(dòng)后、結(jié)束前,不包括啟動(dòng)前和終止后的線程。
  • threading.activeCount():返回正在運(yùn)行的線程數(shù)量,與len(threading.enumerate())有相同的結(jié)果。

1 代碼實(shí)例

from threading import Thread,currentThread,enumerate,activeCount
import time

def task():
    print('子線程 start')
    time.sleep(2)
    print('子線程 end')
    print(enumerate())# 返回一個(gè)包含正在運(yùn)行的線程的list。正在運(yùn)行指線程啟動(dòng)后、結(jié)束前,不包括啟動(dòng)前和終止后的線程。
    print(currentThread(),'子線程') # 返回當(dāng)前的線程變量
    print(activeCount())

if __name__ == '__main__':
   t1 = Thread(target=task)
   t2 = Thread(target=task)
   t1.start()
   t2.start()
   t2.setName('小明')
   print(t2.getName()) # 得到t2的線程名字,是我們?cè)O(shè)置好的小明
   print(t1.getName()) # 得到t1的線程名子 Thread-1
   print(t1.is_alive()) # True

2 join方法

'''
學(xué)習(xí)中遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書(shū)!
'''
from threading import Thread
import time
def task():
    print('子線程 start')
    time.sleep(2)
    print('子線程 end')

t = Thread(target=task)
t.start()
t.join() # 等待子線程運(yùn)行結(jié)束
print('主線程')

六、多線程實(shí)現(xiàn)socket

1 服務(wù)端

import socket
from threading import Thread

socket = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
socket.bind(('192.168.11.78',8004))
socket.listen(5)

def action(conn,addr):
    while True:
        try:

            msg = (conn.recv(1024)).decode('utf8').upper()
            print(f'客戶端{(lán)addr}發(fā)送的數(shù)據(jù)為:{msg.lower()}')
            print(f'向客戶端{(lán)addr}發(fā)送數(shù)據(jù)為',msg)
            conn.send(msg.encode('utf8'))
        except:
            break


if __name__ == '__main__':
    print('等待客戶端連接:')
    while True:
        try:
            conn,addr = socket.accept()
            print(f'客戶端已連接{addr}')
            t = Thread(target=action,args=(conn,addr))
            t.start()
        except:
            print(f'客戶端{(lán)addr}斷開(kāi)連接 ??!')
            break

2 客戶端

import  socket

client = socket.socket()
client.connect(('192.168.11.78',8004))

while True:
    msg = input('輸入:')
    if msg == 'q':
        break
    client.send(msg.encode('utf8'))
    flag = client.recv(1024)
    print('接收服務(wù)端的數(shù)據(jù)為:',flag.decode('utf8'))

到此這篇關(guān)于Python中如何創(chuàng)建多線程?的文章就介紹到這了,更多相關(guān)Python創(chuàng)建多線程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python OpenGL繪制一場(chǎng)煙花盛會(huì)

    Python OpenGL繪制一場(chǎng)煙花盛會(huì)

    正值新春佳節(jié),小編今天為大家?guī)?lái)了用Python OpenGL繪制的一場(chǎng)煙花盛會(huì),文中的實(shí)現(xiàn)步驟講解詳細(xì),感興趣的小伙伴可以跟隨小編一起動(dòng)手試一試
    2022-02-02
  • python使用正則來(lái)處理各種匹配問(wèn)題

    python使用正則來(lái)處理各種匹配問(wèn)題

    這篇文章主要介紹了python使用正則來(lái)處理各種匹配問(wèn)題,本文通過(guò)實(shí)例代碼給大家講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • python將dict中的unicode打印成中文實(shí)例

    python將dict中的unicode打印成中文實(shí)例

    這篇文章主要介紹了python將dict中的unicode打印成中文實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • 如何通過(guò)Python實(shí)現(xiàn)RabbitMQ延遲隊(duì)列

    如何通過(guò)Python實(shí)現(xiàn)RabbitMQ延遲隊(duì)列

    這篇文章主要介紹了如何通過(guò)Python實(shí)現(xiàn)RabbitMQ延遲隊(duì)列,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Python flask框架實(shí)現(xiàn)查詢數(shù)據(jù)庫(kù)并顯示數(shù)據(jù)

    Python flask框架實(shí)現(xiàn)查詢數(shù)據(jù)庫(kù)并顯示數(shù)據(jù)

    這篇文章主要介紹了Python flask框架實(shí)現(xiàn)查詢數(shù)據(jù)庫(kù)并顯示數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Python OpenCV處理圖像之圖像像素點(diǎn)操作

    Python OpenCV處理圖像之圖像像素點(diǎn)操作

    這篇文章主要為大家詳細(xì)介紹了Python OpenCV處理圖像之圖像像素點(diǎn)操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • pandas如何實(shí)現(xiàn)兩個(gè)dataframe相減

    pandas如何實(shí)現(xiàn)兩個(gè)dataframe相減

    這篇文章主要介紹了pandas如何實(shí)現(xiàn)兩個(gè)dataframe相減方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • keras 特征圖可視化實(shí)例(中間層)

    keras 特征圖可視化實(shí)例(中間層)

    今天小編就為大家分享一篇keras 特征圖可視化實(shí)例(中間層),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • python構(gòu)建基礎(chǔ)的爬蟲(chóng)教學(xué)

    python構(gòu)建基礎(chǔ)的爬蟲(chóng)教學(xué)

    在本篇內(nèi)容里小編給大家分享的是關(guān)于python構(gòu)建基礎(chǔ)的爬蟲(chóng)教學(xué)內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2018-12-12
  • Python解決爬蟲(chóng)程序卡死問(wèn)題

    Python解決爬蟲(chóng)程序卡死問(wèn)題

    這篇文章主要介紹了Python解決爬蟲(chóng)程序卡死問(wèn)題,文章圍繞主題展開(kāi)詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05

最新評(píng)論