Rumah >pembangunan bahagian belakang >Tutorial Python >Pengaturcaraan Asynchronous Python: Memudahkan Concurrency Seperti Pro

Pengaturcaraan Asynchronous Python: Memudahkan Concurrency Seperti Pro

Patricia Arquette
Patricia Arquetteasal
2024-11-30 06:38:12862semak imbas

Python Asynchronous Programming: Simplifying Concurrency Like a Pro

Pengenalan: Mengapa Pergi Asynchronous?

Bosan menunggu tugasan lambat selesai? Pengaturcaraan tak segerak membolehkan Python mengendalikan berbilang tugas tanpa menyekat, menjadikan kod anda lebih pantas dan lebih responsif. Mari selami async, tunggu dan asyncio—rakan karib baharu anda untuk keselarasan.


Konsep Teras

  1. Fungsi tak segerak

    Tukar fungsi biasa kepada coroutine yang mampu menjeda dan menyambung semula.

  2. menunggu Kata Kunci

    Membenarkan anda menjeda coroutine sehingga tugasan selesai, membebaskan gelung acara untuk menjalankan tugas lain.

  3. Gelung Acara

    Bos concurrency yang menjadualkan dan menjalankan coroutine.


Contoh: Menjalankan Tugas Asynchronous

import asyncio

async def fetch_data():
    await asyncio.sleep(2)  # Simulates a delay
    return "Data Retrieved"

async def main():
    print(await fetch_data())

asyncio.run(main())  # Outputs: Data Retrieved

Konkurensi Dipermudahkan

Jalankan tugas serentak dengan asyncio.gather:

async def task(name, delay):
    await asyncio.sleep(delay)
    print(f"Task {name} completed!")

async def main():
    await asyncio.gather(
        task("A", 2),
        task("B", 1),
        task("C", 3)
    )

asyncio.run(main())

Di sini, tugasan selesai berdasarkan kelewatannya, tanpa menyekat satu sama lain.


Fikiran Akhir: Python Lebih Pantas, Lebih Pintar

Pengaturcaraan tak segerak membawa kecekapan yang tiada tandingan kepada Python. Dengan async dan menunggu, anda akan mengendalikan tugas serentak seperti profesional—lebih pantas, lebih mudah dan lebih lancar.
? Selamat menulis kod tanpa sekatan dan sepantas kilat!

Atas ialah kandungan terperinci Pengaturcaraan Asynchronous Python: Memudahkan Concurrency Seperti Pro. 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