Rumah >pembangunan bahagian belakang >Tutorial Python >Cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak

Cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak

PHPz
PHPzasal
2023-10-18 09:48:242601semak imbas

Cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak

Cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak

Multi-threading ialah teknologi pengaturcaraan serentak yang biasa digunakan yang boleh meningkatkan kecekapan pelaksanaan program. Dalam Python, multi-threading boleh digunakan untuk melaksanakan tugas secara serentak, dengan itu mempercepatkan kelajuan berjalan program. Artikel ini akan memperkenalkan cara menggunakan multi-threading dalam Python untuk pelaksanaan tugasan serentak dan memberikan contoh kod khusus.

1. Mengapa menggunakan multi-threading

Dalam beberapa kes, program perlu melaksanakan berbilang tugas pada masa yang sama. Sebagai contoh, program perangkak web perlu memuat turun berbilang halaman web pada masa yang sama program pemprosesan data perlu memproses berbilang fail data pada masa yang sama program pemprosesan imej perlu memproses berbilang imej pada masa yang sama, dsb. Jika anda melaksanakan tugasan ini secara bersiri, program akan berjalan lebih perlahan. Penggunaan multi-threading secara berkesan boleh meningkatkan kecekapan pelaksanaan program dan membolehkan berbilang tugasan dilaksanakan serentak.

2. Multithreading dalam Python

Dalam Python, multithreading boleh dicapai melalui modul threading. Modul threading menyediakan kelas Thread untuk mencipta dan memulakan thread baharu dengan mencipta objek contoh kelas Thread. Berikut ialah kod contoh berbilang benang mudah:

import threading

def task():
    # 在这里实现具体的任务逻辑
    pass

# 创建并启动新线程
t = threading.Thread(target=task)
t.start()

# 主线程继续执行其他任务

Dalam kod di atas, fungsi tugas ialah logik tugasan khusus, di mana kita boleh melaksanakan tugasan yang perlu dilaksanakan secara serentak. Anda boleh mencipta utas baharu dengan mencipta objek contoh kelas Thread dan menghantar fungsi tugas sebagai parameter kepada parameter sasaran kelas Thread. Kemudian gunakan kaedah mula untuk memulakan utas baharu, dan utas baharu akan dilaksanakan serentak di latar belakang.

3. Langkah berjaga-jaga untuk melaksanakan tugas berbilang benang secara serentak

Apabila menggunakan berbilang benang untuk pelaksanaan tugas serentak, anda perlu memberi perhatian kepada perkara berikut:

  1. Isu data yang dikongsi antara rangkaian. Berbilang benang boleh mengakses dan mengubah suai data dikongsi pada masa yang sama, dan mekanisme kunci diperlukan untuk memastikan keselamatan benang. Python menyediakan objek Lock dan Rlock untuk melaksanakan mekanisme penguncian mudah.
  2. Isu komunikasi antara benang. Berbilang utas mungkin perlu menukar data semasa pelaksanaan, dan mekanisme seperti baris gilir dan pembolehubah keadaan perlu digunakan untuk mencapai komunikasi antara utas.
  3. Menjadualkan isu antara rangkaian. Berbilang benang mungkin bersaing untuk mendapatkan sumber CPU semasa pelaksanaan, dan algoritma penjadualan perlu digunakan untuk memperuntukkan sumber CPU secara munasabah. Mekanisme GIL (Global Interpreter Lock) dalam Python menyebabkan multi-threading tidak benar-benar mencapai pelaksanaan selari, tetapi untuk mensimulasikan pelaksanaan selari dengan menukar benang dengan cepat pada CPU tunggal.

4 Contoh: Menggunakan multi-threading untuk memuat turun halaman web

Berikut adalah contoh kod untuk menggunakan multi-threading untuk memuat turun halaman web:

import threading
import requests

def download(url):
    # 下载网页的具体逻辑
    response = requests.get(url)
    html = response.text

    # 进一步处理下载的网页
    pass

# 网页列表
urls = [...]
threads = []

# 创建并启动多个线程下载网页
for url in urls:
    t = threading.Thread(target=download, args=(url,))
    t.start()
    threads.append(t)

# 等待所有线程执行完成
for t in threads:
    t.join()

# 主线程继续执行其他任务

Dalam contoh kod di atas, fungsi muat turun digunakan untuk muat turun halaman web. Percepatkan muat turun dengan mencipta berbilang utas dan mulakannya melaksanakan berbilang tugas muat turun secara serentak. Akhir sekali, gunakan kaedah gabungan untuk menunggu semua urutan selesai sebelum meneruskan melaksanakan tugas lain.

Ringkasan:

Artikel ini memperkenalkan cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak dan menyediakan contoh kod khusus. Dalam aplikasi praktikal, kita perlu memberi perhatian kepada isu data dikongsi antara utas, isu komunikasi antara utas dan isu penjadualan antara utas. Dengan menggunakan berbilang benang secara rasional, kecekapan pelaksanaan program dapat dipertingkatkan dan pelaksanaan tugas serentak dapat dicapai.

Atas ialah kandungan terperinci Cara menggunakan multi-threading dalam Python untuk pelaksanaan tugas serentak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn