Skip to content

Latest commit

 

History

History
55 lines (34 loc) · 6.96 KB

File metadata and controls

55 lines (34 loc) · 6.96 KB

مقدمه‌ای بر برنامه‌نویسی غیرهمزمان

تصور کن برنامه‌ات داره کاری انجام می‌ده که نیاز به انتظار داره، مثل گرفتن داده از اینترنت. در برنامه‌نویسی غیرهمزمان، به جای اینکه همه چیز قفل بشه و منتظر بمونی، برنامه در این فاصله سراغ کارهای دیگه می‌ره و وقتی پاسخ رسید، برمی‌گرده ادامه می‌ده. اینطوری زمان هدر نمی‌ره و همه چیز کارآمدتر پیش می‌ره – ساده‌ست، نه؟ بریم ببینیم چطور کار می‌کنه.

برنامه‌نویسی همزمان چیه و چرا گاهی محدودیت داره؟

تا حالا وقتی کد می‌نویسی، دیدی که همه چیز به ترتیب پیش می‌ره؟ اول یک کار تموم می‌شه، بعد بعدی شروع می‌شه. این رو می‌گیم اجرای همزمان (Synchronous). مثلاً اگر برنامه‌ات نیاز به گرفتن داده از اینترنت داشته باشه، تا وقتی پاسخ برنگرده، همه چیز متوقف می‌مونه. حتی اگر CPU بیکار باشه و فقط منتظر شبکه باشه.

این روش برای کارهای ساده عالیه، اما در عمل واقعی، جایی که با شبکه، فایل‌ها یا دیتابیس‌ها سروکار داری، زمان زیادی صرف انتظار می‌شه. آمار نشون می‌ده در اپ‌های مدرن، اغلب ۸۰-۹۰ درصد زمان اجرا مربوط به عملیات I/O مثل درخواست‌های شبکه‌ست. اگر همزمان باشی، منابع سیستم هدر می‌ره و برنامه کند می‌شه.

برنامه‌نویسی غیرهمزمان: استفاده هوشمند از زمان

حالا بیاید سراغ برنامه‌نویسی غیرهمزمان (Asynchronous) بریم. ایده اصلیش اینه: وقتی کاری نیاز به انتظار داره (مثل پاسخ سرور یا خواندن فایل)، برنامه در اون فاصله سراغ کار دیگه‌ای بره. وقتی پاسخ رسید، برمی‌گرده و ادامه می‌ده. اینطوری زمان‌های بیکاری رو به فرصت تبدیل می‌کنی.

این روش اجازه می‌ده هزاران عملیات رو همزمان مدیریت کنی، بدون نیاز به threadهای سنگین که حافظه زیادی مصرف می‌کنن. نتیجه؟ برنامه سریع‌تر، مقیاس‌پذیرتر و کارآمدتر می‌شه. هدفش هوشمندانه‌تر کار کردنه، نه فقط سریع‌تر اجرا شدن.

چندتا مثال ببینیم

بیاید با مثال‌های عملی این مفهوم رو روشن کنیم:

۱. مثال روزمره: سفارش قهوه در کافه شلوغ
فرض کن در یک کافه هستی. اگر همزمان عمل کنی، سفارش می‌دی و وایمیستی تا قهوه آماده بشه (۲ دقیقه انتظار). در این مدت هیچ کار دیگه‌ای نمی‌کنی. اما غیرهمزمان: سفارش می‌دی، می‌ری سر میزت، اینستا چک می‌کنی یا با دوستت حرف می‌زنی. وقتی آماده شد، می‌ری می‌گیریش. زمان کل همونه، اما تو زمان رو مفید سپری کردی. در برنامه‌نویسی، این مثل ارسال درخواست شبکه و ادامه پردازش داده‌های دیگه‌ست.

۲. مثال واقعی: جمع‌آوری داده از وب‌سایت‌های خبری
تصور کن داری یک سیستم می‌سازی که headlineها رو از ۵۰ سایت خبری مثل BBC، CNN یا سایت‌های داخلی جمع می‌کنه. اگر همزمان باشه و هر درخواست ۲ ثانیه طول بکشه، کل کار ۱۰۰ ثانیه می‌شه – کاربر منتظر می‌مونه و تجربه بدی می‌شه.
با رویکرد غیرهمزمان، همه درخواست‌ها تقریباً همزمان ارسال می‌شن. برنامه در حین انتظار برای یکی، جواب بقیه رو پردازش می‌کنه. نتیجه؟ فرآیند ممکنه فقط ۳-۵ ثانیه طول بکشه. این تکنیک در ابزارهایی مثل وب‌اسکریپرهای واقعی یا بات‌های تلگرام استفاده می‌شه.

۳. مثال دیگه: دانلود فایل‌ها همزمان با کارهای دیگه
فرض کن داری چند فایل بزرگ از سرور دانلود می‌کنی و همزمان می‌خوای داده‌ها رو تحلیل کنی. همزمان یعنی اول دانلود تموم بشه، بعد تحلیل شروع. غیرهمزمان اجازه می‌ده دانلود در پس‌زمینه ادامه پیدا کنه و تو همزمان روی داده‌های آماده کار کنی. این در اپ‌هایی مثل کل_operandهای ابری یا استریم ویدیو (مثل Netflix) رایجه، جایی که بارگذاری بافر با پخش هماهنگ می‌شه.

۴. مثال بزرگ‌تر: مدیریت درخواست‌ها در سرور وب
شرکت‌هایی مثل Google یا Amazon از این روش برای هندل کردن میلیون‌ها درخواست استفاده می‌کنن. بدون غیرهمزمان، سرورها از انتظار بیش از حد overload می‌شدن. با این رویکرد، یک سرور می‌تونه هزاران اتصال رو همزمان مدیریت کنه و هزینه‌ها رو تا حد زیادی کم کنه.

مزایا و چالش‌ها

  • مزایا:

    • عالی برای کارهای I/O-bound (شبکه، فایل، دیتابیس).
    • مصرف منابع کمتر نسبت به threadها.
    • مقیاس‌پذیری بالا در اپ‌های واقعی مثل وب‌سرورها.
  • چالش‌ها:

    • کد کمی پیچیده‌تر می‌شه و نیاز به فکر کردن متفاوت داره.
    • برای کارهای CPU-intensive (محاسبات سنگین) مناسب نیست – اونجا بهتره از multiprocessing استفاده کنی.

جمع‌بندی

در نهایت، برنامه‌نویسی غیرهمزمان راهی‌ست برای اینکه برنامه‌ات زمان‌های انتظار رو تلف نکنه و از منابع بهتر استفاده کنه. در درس‌های بعدی، وارد جزئیات می‌شیم: چطور این مفهوم در پایتون با asyncio پیاده می‌شه، از event loop گرفته تا نوشتن coroutines و پروژه‌های عملی.

درس بعدی