Async এবং await (Async & Await)
Async শব্দের অর্থ হলো অসমনিয়ত। মানে হলো আপনি এমন কোন কাজ করতে চাইছেন যেইটা আসলে একটার পর একটা হবে না বা সিরিয়ালি হবে না। তাহলে কেমন করে হবে?
তাহলে বিষয়টা ঘটনা বলি, ধরুন আপনি কোন একটা কুরিয়ার সার্ভিস কোম্পানি এর মালিক।ধরে নিলাম আপনার কোম্পানির নাম হচ্ছে আত্মবিশ্বাস এখন আপনি অনেকের কাজ থেকে পন্য নেন এবং তাদের গন্তব্য স্থলে পৌছে দেন।
ধরুন দিলদার নামে একজন ব্যাক্তি ১১ তারিখ সকাল ১০ঃ০০ টায় পন্য কুরিয়ার সার্ভিসে জমা দিয়েছে যার গন্তব্যস্থল হচ্ছে চট্টগ্রামের কাপ্তাই এলাকা। বাপ্পারাজ নামে আরেকজন তার বউয়ের জন্য শাড়ি পাঠিয়েছে।যার গন্তব্যস্থল হচ্ছে রাঙ্গামাটি এলাকা। জমা দেওয়ার সময় ছিল ১১ তারিখ সকাল ৯ঃ০০ টা ।জসিম নামে আরেক ব্যাক্তি তার বউয়ের জন্য সেলাই মেশিন পাঠিয়েছেন। যার গন্তব্যস্থল হচ্ছে চট্টগ্রামের বদ্দার হাট এলাকা। জমা দেওয়ার সময় ছিল একই তারিখে সকাল ১২ঃ০০টা । এখন আত্মবিশ্বাস কোম্পানির লোকেশন হচ্ছে ঢাকা গুলশান-১ । আপনি যখন পন্য নিয়ে রওনা দিলেন অবশ্যই যার গন্তব্যস্থল আগে অবশ্যই তার পণ্য ডেলিভারি দিবেন ।তার মানে বিষয়টা কিন্তু অন্য রকম হয়ে গেল যে আগে পণ্য জমা দিয়েছে তার পরিবর্তে যার গন্তব্য আগে সে পণ্য পাচ্ছে। আসুন টেবিলের মধ্যমে বিষয়টা আরেকটু বিশ্লেষণ করে দেখি।
আত্মবিশ্বাস গুলশান-১
৩০১ কিঃ মিঃ
কাপ্তাই(দিলদার)
আত্মবিশ্বাস গুলশান-১
৩০৬ কিঃ মিঃ
রাঙ্গামাটি(বাপ্পারাজ)
আত্মবিশ্বাস গুলশান-১
২৫২ কিঃ মিঃ
বদ্দার হাট(জসিম)
এখন আপনি আপনি আশা করি বুঝে নিয়েছেন যে কার টা আগে ডেলিভারি হবে। তো উত্তর হচ্ছে জসিম। কেন? কারণ জসিমের বসার দূরত্ব কম তাই জসিম আগে পাবেন। তারপর দিলদার সাহেবের তারপর বাপ্পারাজ । আর এই যে পুরো বিষয় টা এইটায় হচ্ছে Async বা Asynchronous ।
এবার আসি আসল কথায় আমারা এর আগেই জেনেছি প্রমিস নামে এমন একটা জিনিস আগে থেকেই আছে তাহলে আমারা Async লিখতে যাচ্ছি কেন?
উত্তর হচ্ছে আমরা আসলে প্রমিসের যে সিন্ট্যাক্স সেটাকে ছোট করে লেখার জন্য এমন টা করেছি বা আমাদের কোন ফাংশনে যাতে আমরা খুব সহজে প্রমিস বিষয় টা যুক্ত করতে পারি তার জন্য এমন টা করছি।
তাহলে এবার একটা উদাহরণ দেখে নিই কিভাবে লিখে Async ফাংশন।
রেগুলার ফাংশনের সাথে যদি আমরা async লিখি সে ক্ষেত্রে প্রথমে async কী-ওয়ার্ড এরপর ফাংশন কী-ওয়ার্ড এবং এর পরে ফাংশনের নাম লিখতে হবে। এর পরে আপনার যে statement আছে সেগুলো {} প্রথম বন্ধনী এর মাঝে লিখতে হবে। উপরের কোডটি লক্ষ্য করলে বুঝতে পারবেন।
অ্যারো ফাংশনের সাথে যদি আমরা async লিখি সে ক্ষেত্রে প্রথমে let , const অথবা var কী-ওয়ার্ড লিখতে হবে । এরপরে ফাংশনের নাম লিখতে হবে। এরপরে (=) assignment operator লিখতে হবে এবং পরে async কী-ওয়ার্ড লিখতে হবে। এর পরে আপনার যে statement আছে সেগুলো {} প্রথম বন্ধনী এর মাঝে লিখতে হবে। উপরের কোডটি লক্ষ্য করলে বুঝতে পারবেন।
ক্লাসের সাথে যদি async ফাংশন লিখি সে ক্ষেত্রে ক্লাস সিন্ট্যাক্স লিখে প্রথমে async কী-ওয়ার্ড লিখতে হবে এবং ফাংশনের নাম দিয়ে প্রথম বন্ধনী এর ভিতরে statements গুলো লিখতে হবে।
এখন ফাংশন তো লিখে ফেললেন সেইটা কল করবেন কিভাবে তাও একটা ব্যাপার আছে। Async কল করার দুইটা উপায় আছে একটা হচ্ছে প্রমিসের মতো করে মেথড চেইনিং এবং আরেকটা হচ্ছে await চলুন দেখে নেই সেগুলো কিভাবে লিখে।
এখন আসুন await নামে যে বিষয় টা আছে সেইটার একটু গভীরে যায়। আসলে await বিষয় টা হচ্ছে, আমরা যে বিষয়টা Asynchronous ভাবে করতে চাইছিলাম সেইটা এখন synchronous ভাবে করতে চাইছি মানে আমি আবার এই কাজ টা জাভাস্ক্রিপ্টের ডিফল্ট ওয়েতে করতে চাইছি । আশা করি বুঝতে পেরেছেন। তাছাড়া আমরা যে প্রমিসে then চেইনিং মেথড এর ব্যাবহার করতাম তার কাজটাও কমিয়ে দিচ্ছে। await ব্যবহার করলে তখন আর এই চেইনিং মেথড এর দরকার পরে না তবে চেইনিং মেথড এর ইউস কেইস কিন্তু অন্য ব্যাপার কে বুজায়, বলে রাখলাম।
সিকুয়েন্সিয়াল প্রসেসঃ

উপরের চিত্র দেখে বুঝে যাবেন যে আমরা এইখানে একটা কাজের পর আরেকটা কাজ করছি এর এই বিষয়টা হচ্ছে সিকুয়েন্সিয়াল প্রসেস । যা জাভাস্ক্রিপ্ট ইন্টারপ্রেটারের মধ্যমে Synchronous ভাবে করে।
কনকারেন্সিঃ
কেমন হতো যদি একই সময়কে ভাগ করে নিতে পারতেন মানে একই সময় আপনি একের অধিক কাজ করে ফেলছেন। যেমন ধরুন আপনি মুভি দেখতে দেখতে পপকর্ন খাচ্ছেন আবার সাথে সাথে ফেইসবুকে নিউজ ফিডে আপনার বন্ধু বউয়ের সাথে কক্সবাজার গিয়ে ভিডিও দিয়েছে সেইটা দেখছেন তাই দেখে একই সাথে মন খারাপ করছেন। একটু ভেবে দেখুন তো কাজ গুলো কিন্তু আপনি একটা সময় কে ভাগ করে করে ফেলছেন মানে আপনি কোন একক সময়ে ভিন্ন ভিন্ন কাজ করে ফেলছেন যেইটা আপনি সিকুয়েন্সিয়েলি করতে গেলে টাইম বেশি লাগত।
আশা করি বুঝে গেছেন কনকারেন্সি কি? কনকারেন্সি হচ্ছে কোন একক সময় ভিন্ন ভিন্ন কাজ কে একসাথে করার একটা উপায়।
output:
উপরের কোডটা লক্ষ্য করলে দেখবেন আমি আমি একসাথে অনেকগুলো টাস্ক কে এক্সিকিউশন প্রসেস এর মধ্য দিয়েছি। যেগুলো আসলে Asynchronous টাস্ক সে একটা টাস্কের জন্য এইখানে আমি টাইম বলে দিয়েছি যে একটা টাস্ক কয় মিনিট ধরে এক্সিকিউশন প্রক্রিয়ার মধ্য দিয়ে যাবে। টাইম অনুযায়ী আমার টাস্কটা গুলো কমপ্লিট হওয়ার কথা ছিল ১০০ সেঃ কিন্তু হায়! হায় ! একি হলো? তার আগেই আউটপুট পেয়ে গেলাম তাহলে আমি কি আসলে ভুল কোড লিখলাম ? উত্তর হচ্ছে না। আসুন বিষয়টা বুঝি। এইখানে আসলে যেইটা হয়েছে আমি যে টাইম টা দিয়েছি সেইটা কে সে অন্যভাবে এক্সিকিশন প্রসেসে নিয়ে গেছে।
সে এক সাথে সব টাস্কগুলো গুলোকে প্রসেসে নিয়ে গেছে
আসুন চিত্র এর মধ্যমে দেখি।

বুঝতেই পারছেন প্রথম ১০ সেকেন্ডে প্রথম টাস্ক কমপ্লিট করে ফেলে এবং টিক বাকি টাস্ক গুলো কমপ্লিট হতে ২০ সেকেন্ড লাগবে কারণ ইতিমধ্যেই ১০ সেকেন্ড অতিক্রম হয়ে গেছে পরবর্তী টাস্ক গুলো ২০ সেকেন্ড ধরে এক্সকিউট হয়ে একই সময় পরে আউটপুট দিবে।
NOTE: কিছু সেকেন্ড যেগুলো বেশি দেখছেন এগুলো এই টাস্ক প্রসেস এর সাথে যে অন্যান্য কোড গুলো আছে সেগুলোর ও একটা প্রসেস টাইম আছে তাই ছাড়া External Factors, Precision of Timing এবং Overhead এই রকম অনেক গুলো ফ্যাক্টর আছে যার কারনে ৩০ সেকেন্ড থেকেও একটু বেশি সময় লেগেছে।
প্যরালাললিজমঃ
Parallelism বিষয়টা দেখতে অনেকটা কনকারেন্সি এর মতো দেখালেও কিন্তু একই না । নিচের চিত্রটি দেখুন।

একটু যদি ভাল করে লক্ষ্য করুন দেখবেন বিষয় একটু ভিন্নতা আছে আগের উদাহরণে কিন্তু আপনি একটা করছিলেন সব কিন্তু আমাদের এবারের চিত্রে কিন্তু আলাদা আলাদা মানুষ কাজ গুলো সম্পন্ন করছে। এবং তারা তাদের মত করে আলাদা স্পেসে করছে এবং আলাদা টাইমে করছে। এইটাই মূলত প্যারালালিজম । একই সময়ে ভিন্ন ভিন্ন থ্রেড দ্বারা কাজ করায় হচ্ছে প্যারালালিজম। আসুন এবার কোড করে বিষয়টা বুঝে নেই।
জাভাস্ক্রিপ্টে কিন্তু worker নামে একটা বিল্ডিইন এপি আই আছে যেইটা আমাদের একই সময় আলাদা আলাদা থ্রেড ব্যবহারের সুবিধা দিয়ে থাকে।
সেই Worker API দিয়ে আমরা প্রথমে কিছু Worker বানিয়ে নেই brush-worker.js, clean-worker.js, cook-worker.js, watch-tv-worker.js নামে নিচের মতো করে এবং কোড গুলো লিখে নেই।
আমাদের Worker বানানো শেষ হলে এখন আমরা সেই Worker গুলো মেইন থ্রেডে নিয়ে আসব তাই প্রথমেই main.js নামে একটা ফাইল বানাব এবং নিচে লেখা কোডের মতো করে Worker গুলো ইমপ্লিমেন্ট করে নিব। করা
করা শেষ হলে এখন আমরা Worker এ আমাদের মেইন থ্রেড থেকে মেসেজ পাঠাবো ৩, ৭ , ১১ এবং ১৫ নাম্বার লাইনের মতো করে। এবার আমরা সে আমাদের Worker এর সাথে যোগাযোগ করে আমাদের যে ডাটা দিবে সেই ডাটা আমরা রিসিভ করব। ১৮,২২, ২৬ এবং ৩০ নাম্বার লাইনের মতো করে। ব্যাস আমাদের কাজ শেষ। ওয়ার্কার গুলো তাদের মতো করে কমিউনিকেশন করে নিবে এবং ডাটা দিয়ে দিবে কোন সমস্যা ছাড়াই। Worker এপি আই নিয়ে আমি আরো বিস্তারিত লিখেছি ওয়েব এপি আই অধ্যায়ে তাই এইখানে আর বেশি বললাম না।
Last updated