吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

python創(chuàng)建多線程的兩種方法

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-03-15 16:47 ? 次閱讀

1. 用函數(shù)創(chuàng)建多線程

Python3中,Python提供了一個內置模塊 threading.Thread,可以很方便地讓我們創(chuàng)建多線程。

threading.Thread() 一般接收兩個參數(shù)

線程函數(shù)名:要放置線程讓其后臺執(zhí)行的函數(shù),由我們自已定義,注意不要加()

線程函數(shù)的參數(shù):線程函數(shù)名所需的參數(shù),以元組的形式傳入。若不需要參數(shù),可以不指定。

舉個例子

import time
from threading import Thread

# 自定義線程函數(shù)。
def target(name="Python"):
    for i in range(2):
        print("hello", name)
        time.sleep(1)

# 創(chuàng)建線程01,不指定參數(shù)
thread_01 = Thread(target=target)
# 啟動線程01
thread_01.start()


# 創(chuàng)建線程02,指定參數(shù),注意逗號
thread_02 = Thread(target=target, args=("MING",))
# 啟動線程02
thread_02.start()

可以看到輸出

hello Python
hello MING
hello Python
hello MING

2. 用類創(chuàng)建多線程

相比較函數(shù)而言,使用類創(chuàng)建線程,會比較麻煩一點。

首先,我們要自定義一個類,對于這個類有兩點要求,

必須繼承 threading.Thread 這個父類;

必須復寫 run 方法。

這里的 run 方法,和我們上面線程函數(shù)的性質是一樣的,可以寫我們的業(yè)務邏輯程序。在 start() 后將會調用。

來看一下例子 為了方便對比,run函數(shù)我復用上面的main

import time
from threading import Thread

class MyThread(Thread):
    def __init__(self, type="Python"):
        # 注意:super().__init__() 必須寫
        # 且最好寫在第一行
        super().__init__()
        self.type=type

    def run(self):
        for i in range(2):
            print("hello", self.type)
            time.sleep(1)

if __name__ == '__main__':
    # 創(chuàng)建線程01,不指定參數(shù)
    thread_01 = MyThread()
    # 創(chuàng)建線程02,指定參數(shù)
    thread_02 = MyThread("MING")

    thread_01.start()
    thread_02.start()

當然結果也是一樣的。

hello Python
hello MING
hello Python
hello MING

3. 線程對象的方法

上面介紹了當前 Python 中創(chuàng)建線程兩種主要方法。

創(chuàng)建線程是件很容易的事,但要想用好線程,還需要學習線程對象的幾個函數(shù)。

經過我的總結,大約常用的方法有如下這些:

# 如上所述,創(chuàng)建一個線程
t=Thread(target=func)

# 啟動子線程
t.start()

# 阻塞子線程,待子線程結束后,再往下執(zhí)行
t.join()

# 判斷線程是否在執(zhí)行狀態(tài),在執(zhí)行返回True,否則返回False
t.is_alive()
t.isAlive()

# 設置線程是否隨主線程退出而退出,默認為False
t.daemon = True
t.daemon = False

# 設置線程名
t.name = "My-Thread"

審核編輯:符乾江
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 多線程
    +關注

    關注

    0

    文章

    278

    瀏覽量

    20074
  • python
    +關注

    關注

    56

    文章

    4807

    瀏覽量

    85037
收藏 人收藏

    評論

    相關推薦

    socket 多線程編程實現(xiàn)方法

    在現(xiàn)代網絡編程中,多線程技術被廣泛應用于提高服務器的并發(fā)處理能力。Socket編程是網絡通信的基礎,而將多線程技術應用于Socket編程,可以顯著提升服務器的性能。 多線程編程的基本概念 多線
    的頭像 發(fā)表于 11-12 14:16 ?466次閱讀

    Python多線程和多進程的區(qū)別

    Python作為一種高級編程語言,提供了多種并發(fā)編程的方式,其中多線程與多進程是最常見的兩種方式之一。在本文中,我們將探討Python多線程
    的頭像 發(fā)表于 10-23 11:48 ?493次閱讀
    <b class='flag-5'>Python</b>中<b class='flag-5'>多線程</b>和多進程的區(qū)別

    一文掌握Python多線程

    使用線程可以把占據(jù)長時間的程序中的任務放到后臺去處理。
    的頭像 發(fā)表于 08-05 15:46 ?920次閱讀

    ESP32會不會有多線程問題,需要加鎖嗎?

    ESP32會不會有多線程問題,需要加鎖嗎
    發(fā)表于 07-19 08:05

    多線程設計模式到對 CompletableFuture 的應用

    最近在開發(fā) 延保服務 頻道頁時,為了提高查詢效率,使用到了多線程技術。為了對多線程方案設計有更加充分的了解,在業(yè)余時間讀完了《圖解 Java 多線程設計模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?430次閱讀
    從<b class='flag-5'>多線程</b>設計模式到對 CompletableFuture 的應用

    數(shù)字設備中采集數(shù)字圖像的兩種方法是什么

    在數(shù)字設備中,采集數(shù)字圖像的方法有很多種,但最常見的兩種方法是:1) 使用數(shù)字相機拍攝,2) 通過掃描儀掃描。 一、使用數(shù)字相機拍攝 數(shù)字相機是一種可以捕捉圖像并將其轉換為數(shù)字格式的設備。數(shù)字相機
    的頭像 發(fā)表于 05-31 15:48 ?947次閱讀

    bootloader開多線程做引導程序,跳app初始化后直接進hardfualt,為什么?

    如標題,想做一個遠程升級的項目,bootloader引導區(qū)域和app都是開多線程跑的,就是自己寫了個小的任務調度器,沒什么功能主要是想讓程序快速的響應,延時不會對其他程序造成堵塞,程序測試
    發(fā)表于 04-18 06:07

    鴻蒙原生應用開發(fā)-ArkTS語言基礎類庫多線程并發(fā)概述

    的功能,它允許在不同的進程間傳遞對象的引用,使得不同進程之間可以共享對象的狀態(tài)和方法,服務提供者必須繼承此類。 二、TaskPool和Worker ArkTS提供了TaskPool和Worker兩種并發(fā)
    發(fā)表于 03-28 14:35

    鴻蒙APP開發(fā):【ArkTS類庫多線程】TaskPool和Worker的對比(2)

    創(chuàng)建Worker的線程稱為宿主線程(不一定是主線程,工作線程也支持創(chuàng)建Worker子
    的頭像 發(fā)表于 03-27 15:44 ?578次閱讀
    鴻蒙APP開發(fā):【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比(2)

    鴻蒙原生應用開發(fā)-ArkTS語言基礎類庫多線程TaskPool和Worker的對比(一)

    TaskPool(任務池)和Worker的作用是為應用程序提供一個多線程的運行環(huán)境,用于處理耗時的計算任務或其他密集型任務。可以有效地避免這些任務阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗
    發(fā)表于 03-25 14:11

    鴻蒙原生應用開發(fā)-ArkTS語言基礎類庫多線程I/O密集型任務開發(fā)

    使用異步并發(fā)可以解決單次I/O任務阻塞的問題,但是如果遇到I/O密集型任務,同樣會阻塞線程中其它任務的執(zhí)行,這時需要使用多線程并發(fā)能力來進行解決。 I/O密集型任務的性能重點通常不在于CPU的處理
    發(fā)表于 03-21 14:57

    java實現(xiàn)多線程的幾種方式

    的CompletableFuture 一、繼承Thread類 繼承Thread類是實現(xiàn)多線程的最基本方式,只需創(chuàng)建一個類并繼承Thread類,重寫run()方法即可。 ``
    的頭像 發(fā)表于 03-14 16:55 ?782次閱讀

    python中5種線程鎖盤點

    線程安全是多線程或多進程編程中的一個概念,在擁有共享數(shù)據(jù)的多條線程并行執(zhí)行的程序中,線程安全的代碼會通過同步機制保證各個線程都可以正常且正確
    發(fā)表于 03-07 11:08 ?1671次閱讀
    <b class='flag-5'>python</b>中5種<b class='flag-5'>線程</b>鎖盤點

    AT socket可以多線程調用嗎?

    請問AT socket 可以多線程調用嗎? 有互鎖機制嗎,還是要自己做互鎖。
    發(fā)表于 03-01 08:22

    linux多線程編程實例

    linux線程
    的頭像 發(fā)表于 02-15 21:16 ?528次閱讀
    linux<b class='flag-5'>多線程</b>編程實例
    罗盘的 24卦位| 博之道百家乐官网的玩法技巧和规则| 六合彩摇奖结果| 一筒百家乐的玩法技巧和规则| 实战百家乐官网的玩法技巧和规则 | 百家乐官网投注打三断| 大发8888迅雷下载免费| 百家乐论坛代理合作| 巴厘岛百家乐官网娱乐城| 澳门百家乐官网国际| 永利高足球博彩网| 大发888娱乐城电话| 百家乐是怎样算牌| 肯博百家乐游戏| 百家乐官网游戏试| 金冠百家乐官网娱乐城| bet365高尔夫娱乐场| 全讯网3344111.com| 百家乐双层筹码盘| 百家乐官网桌子定制| 百家乐官网娱乐平台真人娱乐平台 | 百家乐官网沙| 百家乐官网注码技巧| 卡卡湾网上娱乐| 大发888赢钱最多的| 百家乐策略网络游戏信誉怎么样 | 百家乐官网游戏源码手机| 百家乐官网游戏平台架设| 临清市| 真人斗地主| 济州岛娱乐场小伊| 大发888博彩娱乐城| 百家乐高| 百家乐游戏解码器| 百家乐和抽水官网| 百家乐太阳城开户| 百家乐官网软件代理打| 百家乐官网有诈吗| 百家乐官网娱乐平台真人娱乐平台| 网络百家乐官网棋牌| 百家乐官网开户百家乐官网技巧|