


Master Python Coroutines: Cipta Alat Async Tersuai untuk Apl Serentak Berkuasa
Coroutine dalam Python ialah alat yang berkuasa untuk menulis kod tak segerak. Mereka telah merevolusikan cara kami mengendalikan operasi serentak, menjadikannya lebih mudah untuk membina aplikasi berskala dan cekap. Saya telah menghabiskan banyak masa bekerja dengan coroutine dan saya teruja untuk berkongsi beberapa cerapan tentang mencipta primitif tak segerak tersuai.
Mari kita mulakan dengan perkara asas. Coroutine ialah fungsi khas yang boleh dijeda dan disambung semula, membolehkan kerja berbilang tugas secara kooperatif. Mereka adalah asas sintaks async/menunggu Python. Apabila anda mentakrifkan coroutine, anda pada asasnya mencipta fungsi yang boleh menghasilkan kawalan kembali kepada gelung acara, membenarkan tugasan lain dijalankan.
Untuk mencipta objek tersuai yang boleh ditunggu, anda perlu melaksanakan kaedah menunggu. Kaedah ini harus mengembalikan iterator. Berikut ialah contoh mudah:
class CustomAwaitable: def __init__(self, value): self.value = value def __await__(self): yield return self.value async def use_custom_awaitable(): result = await CustomAwaitable(42) print(result) # Output: 42
Kelas CustomAwaitable ini boleh digunakan dengan kata kunci await, sama seperti awaitable terbina dalam. Apabila ditunggu, ia menghasilkan kawalan sekali, kemudian mengembalikan nilainya.
Tetapi bagaimana jika kita mahu mencipta primitif tak segerak yang lebih kompleks? Mari kita lihat melaksanakan semafor tersuai. Semaphore digunakan untuk mengawal akses kepada sumber yang dikongsi oleh berbilang coroutine:
import asyncio class CustomSemaphore: def __init__(self, value=1): self._value = value self._waiters = [] async def acquire(self): while self._value <p>Kelas CustomSemaphore ini melaksanakan kaedah peroleh dan keluarkan, serta protokol pengurus konteks async (<strong>aenter</strong> dan <strong>aexit</strong>). Ia membenarkan maksimum dua coroutine untuk memperoleh semaphore secara serentak.</p> <p>Sekarang, mari kita bincangkan tentang mencipta gelung acara yang cekap. Walaupun asyncio Python menyediakan pelaksanaan gelung acara yang mantap, mungkin terdapat kes di mana anda memerlukan yang tersuai. Berikut ialah contoh asas gelung acara tersuai:<br> </p> <pre class="brush:php;toolbar:false">import time from collections import deque class CustomEventLoop: def __init__(self): self._ready = deque() self._stopping = False def call_soon(self, callback, *args): self._ready.append((callback, args)) def run_forever(self): while not self._stopping: self._run_once() def _run_once(self): ntodo = len(self._ready) for _ in range(ntodo): callback, args = self._ready.popleft() callback(*args) def stop(self): self._stopping = True def run_until_complete(self, coro): def _done_callback(fut): self.stop() task = self.create_task(coro) task.add_done_callback(_done_callback) self.run_forever() return task.result() def create_task(self, coro): task = Task(coro, self) self.call_soon(task._step) return task class Task: def __init__(self, coro, loop): self._coro = coro self._loop = loop self._done = False self._result = None self._callbacks = [] def _step(self): try: if self._done: return result = self._coro.send(None) if isinstance(result, SleepHandle): result._task = self self._loop.call_soon(result._wake_up) else: self._loop.call_soon(self._step) except StopIteration as e: self.set_result(e.value) def set_result(self, result): self._result = result self._done = True for callback in self._callbacks: self._loop.call_soon(callback, self) def add_done_callback(self, callback): if self._done: self._loop.call_soon(callback, self) else: self._callbacks.append(callback) def result(self): if not self._done: raise RuntimeError('Task is not done') return self._result class SleepHandle: def __init__(self, duration): self._duration = duration self._task = None self._start_time = time.time() def _wake_up(self): if time.time() - self._start_time >= self._duration: self._task._loop.call_soon(self._task._step) else: self._task._loop.call_soon(self._wake_up) async def sleep(duration): return SleepHandle(duration) async def example(): print("Start") await sleep(1) print("After 1 second") await sleep(2) print("After 2 more seconds") return "Done" loop = CustomEventLoop() result = loop.run_until_complete(example()) print(result)
Gelung acara tersuai ini melaksanakan fungsi asas seperti menjalankan tugas, mengendalikan coroutine dan juga fungsi tidur yang ringkas. Ia tidak sekaya ciri seperti gelung acara terbina dalam Python, tetapi ia menunjukkan konsep teras.
Salah satu cabaran dalam menulis kod tak segerak ialah mengurus keutamaan tugas. Walaupun asyncio Python tidak menyediakan baris gilir keutamaan terbina dalam untuk tugasan, kami boleh melaksanakan tugas kami sendiri:
import asyncio import heapq class PriorityEventLoop(asyncio.AbstractEventLoop): def __init__(self): self._ready = [] self._stopping = False self._clock = 0 def call_at(self, when, callback, *args, context=None): handle = asyncio.Handle(callback, args, self, context) heapq.heappush(self._ready, (when, handle)) return handle def call_later(self, delay, callback, *args, context=None): return self.call_at(self._clock + delay, callback, *args, context=context) def call_soon(self, callback, *args, context=None): return self.call_at(self._clock, callback, *args, context=context) def time(self): return self._clock def stop(self): self._stopping = True def is_running(self): return not self._stopping def run_forever(self): while self._ready and not self._stopping: self._run_once() def _run_once(self): if not self._ready: return when, handle = heapq.heappop(self._ready) self._clock = when handle._run() def create_task(self, coro): return asyncio.Task(coro, loop=self) def run_until_complete(self, future): asyncio.futures._chain_future(future, self.create_future()) self.run_forever() if not future.done(): raise RuntimeError('Event loop stopped before Future completed.') return future.result() def create_future(self): return asyncio.Future(loop=self) async def low_priority_task(): print("Low priority task started") await asyncio.sleep(2) print("Low priority task finished") async def high_priority_task(): print("High priority task started") await asyncio.sleep(1) print("High priority task finished") async def main(): loop = asyncio.get_event_loop() loop.call_later(0.1, loop.create_task, low_priority_task()) loop.call_later(0, loop.create_task, high_priority_task()) await asyncio.sleep(3) asyncio.run(main())
PriorityEventLoop ini menggunakan baris gilir timbunan untuk mengurus tugasan berdasarkan masa pelaksanaan yang dijadualkan. Anda boleh menetapkan keutamaan dengan menjadualkan tugas dengan kelewatan yang berbeza.
Mengendalikan pembatalan dengan baik adalah satu lagi aspek penting dalam bekerja dengan coroutine. Berikut ialah contoh cara melaksanakan tugas yang boleh dibatalkan:
import asyncio async def cancellable_operation(): try: print("Operation started") await asyncio.sleep(5) print("Operation completed") except asyncio.CancelledError: print("Operation was cancelled") # Perform any necessary cleanup raise # Re-raise the CancelledError async def main(): task = asyncio.create_task(cancellable_operation()) await asyncio.sleep(2) task.cancel() try: await task except asyncio.CancelledError: print("Main: task was cancelled") asyncio.run(main())
Dalam contoh ini, cancelled_operation menangkap CancelledError, melakukan sebarang pembersihan yang diperlukan, dan kemudian menaikkan semula pengecualian. Ini membolehkan pengendalian pembatalan yang bijak sambil masih menyebarkan status pembatalan.
Mari kita terokai melaksanakan iterator async tersuai. Ini berguna untuk mencipta jujukan yang boleh diulang secara tidak segerak:
class CustomAwaitable: def __init__(self, value): self.value = value def __await__(self): yield return self.value async def use_custom_awaitable(): result = await CustomAwaitable(42) print(result) # Output: 42
Kelas AsyncRange ini melaksanakan protokol lelaran async, membenarkan ia digunakan dalam async untuk gelung.
Akhir sekali, mari kita lihat melaksanakan pengurus konteks async tersuai. Ini berguna untuk mengurus sumber yang perlu diperoleh dan dikeluarkan secara tak segerak:
import asyncio class CustomSemaphore: def __init__(self, value=1): self._value = value self._waiters = [] async def acquire(self): while self._value <p>Kelas AsyncResource ini melaksanakan kaedah <strong>aenter</strong> dan <strong>aexit</strong>, membenarkan ia digunakan dengan penyataan async dengan.</p> <p>Kesimpulannya, sistem coroutine Python menyediakan asas yang kuat untuk membina primitif tak segerak tersuai. Dengan memahami mekanisme dan protokol asas, anda boleh mencipta penyelesaian yang disesuaikan untuk cabaran tak segerak tertentu, mengoptimumkan prestasi dalam senario serentak yang kompleks dan memanjangkan keupayaan async Python. Ingat, walaupun pelaksanaan tersuai ini bagus untuk pembelajaran dan kes penggunaan khusus, perpustakaan asyncio terbina dalam Python sangat dioptimumkan dan harus menjadi pilihan anda untuk kebanyakan senario. Selamat mengekod!</p> <hr> <h2> Ciptaan Kami </h2> <p>Pastikan anda melihat ciptaan kami:</p> <p><strong>Pusat Pelabur</strong> | <strong>Hidup Pintar</strong> | <strong>Epos & Gema</strong> | <strong>Misteri Membingungkan</strong> | <strong>Hindutva</strong> | <strong>Pembangunan Elit</strong> | <strong>Sekolah JS</strong></p> <hr> <h3> Kami berada di Medium </h3> <p><strong>Tech Koala Insights</strong> | <strong>Dunia Epok & Gema</strong> | <strong>Medium Pusat Pelabur</strong> | <strong>Medium Misteri Membingungkan</strong> | <strong>Sains & Zaman Sederhana</strong> | <strong>Hindutva Moden</strong></p>
Atas ialah kandungan terperinci Master Python Coroutines: Cipta Alat Async Tersuai untuk Apl Serentak Berkuasa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Tomergelistsinpython, operator youCanusethe, extendmethod, listcomprehension, oritertools.chain, eachwithspecificadvantages: 1) operatorSimpleButlessefficientficorlargelists;

Dalam Python 3, dua senarai boleh disambungkan melalui pelbagai kaedah: 1) Pengendali penggunaan, yang sesuai untuk senarai kecil, tetapi tidak cekap untuk senarai besar; 2) Gunakan kaedah Extend, yang sesuai untuk senarai besar, dengan kecekapan memori yang tinggi, tetapi akan mengubah suai senarai asal; 3) menggunakan * pengendali, yang sesuai untuk menggabungkan pelbagai senarai, tanpa mengubah suai senarai asal; 4) Gunakan itertools.chain, yang sesuai untuk set data yang besar, dengan kecekapan memori yang tinggi.

Menggunakan kaedah Join () adalah cara yang paling berkesan untuk menyambungkan rentetan dari senarai di Python. 1) Gunakan kaedah Join () untuk menjadi cekap dan mudah dibaca. 2) Kitaran menggunakan pengendali tidak cekap untuk senarai besar. 3) Gabungan pemahaman senarai dan menyertai () sesuai untuk senario yang memerlukan penukaran. 4) Kaedah mengurangkan () sesuai untuk jenis pengurangan lain, tetapi tidak cekap untuk penyambungan rentetan. Kalimat lengkap berakhir.

PythonexecutionistheprocessoftransformingpythoncodeIntoExecutableInstructions.1) TheinterpreterreadsTheCode, convertingIntoByteCode, yang mana -mana

Ciri -ciri utama Python termasuk: 1. Sintaks adalah ringkas dan mudah difahami, sesuai untuk pemula; 2. Sistem jenis dinamik, meningkatkan kelajuan pembangunan; 3. Perpustakaan standard yang kaya, menyokong pelbagai tugas; 4. Komuniti dan ekosistem yang kuat, memberikan sokongan yang luas; 5. Tafsiran, sesuai untuk skrip dan prototaip cepat; 6. Sokongan multi-paradigma, sesuai untuk pelbagai gaya pengaturcaraan.

Python adalah bahasa yang ditafsirkan, tetapi ia juga termasuk proses penyusunan. 1) Kod python pertama kali disusun ke dalam bytecode. 2) Bytecode ditafsirkan dan dilaksanakan oleh mesin maya Python. 3) Mekanisme hibrid ini menjadikan python fleksibel dan cekap, tetapi tidak secepat bahasa yang disusun sepenuhnya.

UseAforLoopWheniteratingOvereForforpecificNumbimes; Useaphileloopwhencontinuinguntilaconditionismet.forloopsareidealforknownownsequences, sementara yang tidak digunakan.

Pythonloopscanleadtoerrorslikeinfiniteloops, pengubahsuaianListsduringiteration, off-by-oneerrors, sifar-indexingissues, andnestedloopinefficies.toavoidthese: 1) use'i


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini
