2.5 এক্সিকিউশন কনটেক্সট
এক্সিকিউশন কন্টেক্সট একটি এনভাইরনমেন্ট যেখানে জাভাস্ক্রিপ্ট কোড এক্সিকিউট করা হয়। যখনই জাভাস্ক্রিপ্টে কোন কোড রান করা হয়, এটি একটি এক্সিকিউশন কন্টেক্সটের মধ্যে রান করা হয়। জাভাস্ক্রিপ্টে তিন ধরনের এক্সিকিউশন কন্টেক্সট আছেঃ-
১) গ্লোবাল এক্সিকিউশন কন্টেক্সট:
এটি ডিফল্ট এক্সিকিউশন কন্টেক্সট। যে কোডটি কোন ফাংশনের ভিতরে নেই তা গ্লোবাল এক্সিকিউশন কন্টেক্সটে আছে। এটি দুটি জিনিস সম্পন্ন করেঃ
- এটি একটি গ্লোবাল অবজেক্ট তৈরি করে যা একটি window অবজেক্ট (ব্রাউজারের ক্ষেত্রে) এবং global অবজেক্ট (নোডের ক্ষেত্রে)
- this এর ভ্যালু হিসাবে গ্লোবাল অবজেক্টকে সেট করে। একটি প্রোগ্রামে শুধুমাত্র একটি গ্লোবাল এক্সিকিউশন কন্টেক্সট থাকতে পারে।
২) ফাংশন এক্সিকিউশন কন্টেক্সটঃ
যখনই কোন ফাংশন কল করা হয়, সেই ফাংশনের জন্য জেএস ইঞ্জিন একটি নতুন এক্সিকিউশন কন্টেক্সট তৈরি করে। প্রতিটি ফাংশনের নিজস্ব এক্সিকিউশন কন্টেক্সট আছে। একাধিক সংখ্যক ফাংশন এক্সিকিউশন কন্টেক্সট হতে পারে। ফাংশন এক্সিকিউশন কন্টেক্সটের গ্লোবাল এক্সিকিউশন কন্টেক্সটের সকল কোড অ্যাক্সেস আছে যদিও গ্লোবাল কন্টেক্সটের ফাংশন এক্সিকিউশন কন্টেক্সটের কোডের অ্যাক্সেস নেই। গ্লোবাল এক্সিকিউশন কন্টেক্সটের কোড এক্সিকিউট করার সময় যদি জেএস ইঞ্জিন কোন ফাংশন কল পায়, এটি সেই ফাংশনের জন্য একটি নতুন ফাংশন এক্সিকিউশন কন্টেক্সট তৈরি করে। ব্রাউজার কন্টেক্সটে, যদি কোড strict মোডে এক্সিকিউট করা হয়, তাহলে this এর ভ্যালু undefined অন্যথায় window অবজেক্ট হবে ফাংশন এক্সিকিউশন কন্টেক্সট।
৩) ইভাল এক্সিকিউশন কন্টেক্সটঃ
ইভাল ফাংশনের ভিতরে এক্সিকিউশন কন্টেক্সট।
নিম্নলিখিত কোড দেখুনঃ
let a = 7;
const multByTen = (a) => a * 10;
let results = multByTen(a);
console.log(results); // 70
উপরের কোডে লক্ষ্য করুনঃ
- প্রথমে, a ভ্যারিয়েবলে 7 অ্যাসাইন করা হয়েছে।
- দ্বিতীয়ত, একটি ফাংশন multByTen() ডিক্লেয়ার করা হয়েছে যা 10 এর সাথে তার আর্গুমেন্ট কে গুণ করে।
- তৃতীয়ত, একটি প্যারামিটার হিসাবে a পাস করে multByTen() ফাংশনকে কল করে এবং ভ্যারিয়েবল results – এ রিটার্ন মান অ্যাসাইন করা হয়েছে।
- পরিশেষে, কনসোলে ভ্যারিয়েবল results আউটপুট করা হয়েছে।
অনেক সহজ কোডটা তাই না? যাইহোক, বিহাইন্ড দ্যা সিন জাভাস্ক্রিপ্ট অনেক কিছু করে। ইতিমধ্যে আমরা এক্সিকিউশন কন্টেক্সট সম্পর্কে জেনে গেছি। কিন্তু প্রতিটি এক্সিকিউশন কন্টেক্সটে দুটি করে phases আছেঃ ১। creation phase এবং ২। execution phase।
১। Creation phase
- একটি গ্লোবাল অবজেক্ট তৈরি করে অর্থাৎ, ওয়েব ব্রাউজারে window বা নোড জেএসে global।
- this নামে একটি গ্লোবাল ভ্যারিয়াবল তৈরি করে যা গ্লোবাল অবজেক্টকে নির্দেশ করে।
- সকল ভ্যারিয়েবল এবং ফাংশনের জন্য একটি মেমোরি স্পেস সেটআপ করে।
- ভ্যারিয়েবলের ডিফল্ট ভ্যালু হিসাবে undefined অ্যাসাইন করে এবং ফাংশন ডিক্লেয়ারেশনগুলি হীপ মেমোরিতে স্টোর করে।
আমাদের উদাহরণে, creation phase – এ জাভাস্ক্রিপ্ট ইঞ্জিন গ্লোবাল এক্সিকিউশন কন্টেক্সটে ভ্যারিয়েবল a ও results এবং ফাংশন ডিক্লেয়ারেশন multByTen() স্টোর করে। এছাড়াও, এটি ভ্যারিয়েবল a এবং results কে undefined হিসাবে ইনিশিয়ালাইজ করে।
Global Execution Context (Execution Phase Browser)
- window: Global Object
- this: window
- a: undefined
- multByTen: fn()
- results: undefined
Creation phase এর পর, গ্লোবাল এক্সিকিউশন কন্টেক্সট execution phase শুরু করে।
২) Execution phase
Execution phase – এ, জাভাস্ক্রিপ্ট ইঞ্জিন লাইন বাই লাইন কোড এক্সিকিউট করে। এই phase -এ, এটি ভ্যারিয়েবলের মান অ্যাসাইন করে এবং ফাংশন কল এক্সিকিউট করে।
Global Execution Context (Execution Phase Browser)
- window: Global Object
- this: window
- a: 7
- multByTen: fn()
- results: multByTen(a)
আমরা আগেই জেনেছি প্রতিটি ফাংশন কলের জন্য জাভাস্ক্রিপ্ট ইঞ্জিন একটি নতুন ফাংশন এক্সিকিউশন কন্টেক্সট তৈরি করে। ফাংশন এক্সিকিউশন কন্টেক্সট গ্লোবাল এক্সিকিউশন কন্টেক্সটের মতই কিন্তু ফাংশন এক্সিকিউশন কন্টেক্সট গ্লোবাল অবজেক্ট তৈরি করার পরিবর্তে এটি arguments অবজেক্ট তৈরি করে যা ফাংশনে পাস করা সকল প্যারামিটারের একটি রেফারেন্স ধারণ করে:
Function Execution Context (Creation Phase Browser)
- arguments: Local Object
- this: window
- a: undefined
আমাদের উদাহরণে, ফাংশন এক্সিকিউশন কন্টেক্সট arguments অবজেক্ট তৈরি করে যা ফাংশনে পাস করা সকল প্যারামিটারকে নির্দেশ করে, this এর মান হিসাবে গ্লোবাল অবজেক্টে window কে সেট করে। এবং a প্যারামিটার কে undefined হিসাবে ইনিশিয়ালাইজ করে।
Function Execution Context (Execution Phase Browser)
- arguments: Local Object
- this: window
- a: 7
ফাংশন এক্সিকিউশন কন্টেক্সটে Execution phase চলার সময়, এটি a প্যারামিটারে 7 অ্যাসাইন করে এবং ফলাফল (70) গ্লোবাল এক্সিকিউশন কন্টেক্সটের results ভ্যারিয়েবলে রিটার্ন করে।
Global Execution Context (Execution Phase Browser)
- window: Global Object
- this: window
- a: 7
- multByTen: fn()
- results: 70
- নিচের উদাহরণটি দেখুন কিভাবে আউটপুট 100 আসেlet x = 10;function timesTen(a){return a * 10;}let y = timesTen(x);console.log(y);
- নিচের কোডটি রান করুন এবং দেখুন কি আউটপুট আসেfunction a() {console.log(‘It is the first function’);function b() {console.log(‘It is the second function’);}b();}a();console.log(‘It is GEC’);
- নিচের কোডটি রান করুন এবং দেখুন কি আউটপুট আসেfunction first() {setTimeout(() => {console.log(‘It is the first function’);}, 3000);function second() {console.log(‘It is the second function’);}second();}first();console.log(‘It is GEC’);
- নিচের কোডটি রান করুন এবং দেখুন কি আউটপুট আসেlet a = 20;const b = 30;var mul;function multiply(e, f) {var g = 20;return e * f * g;}mul = multiply(a, b);console.log(mul)
- নিচের কোডটি রান করুন এবং দেখুন কি আউটপুট আসেconsole.log(‘Global Execution context’)function fn1() {setTimeout(() => {console.log(‘Inside function fn1 with the SetTimeout of 3 seconds’);}, 3000);}setTimeout(() => {console.log(‘Inside the Global Execution context With SetTimeout of 10 seconds’);}, 10000);function fn2() {console.log(‘inside function fn2’);}function fn3(){setTimeout(() => {console.log(‘Inside function fn3 with the SetTimeout of 3 seconds’);}, 3000);}fn1();fn2();fn3();console.log(‘Last line Output of Global Execution Context’);
- নিচের কোডটি রান করুন এবং দেখুন কি আউটপুট আসেfunction f1() {console.log(‘Inside f1’);function f2() {setTimeout(() => {console.log(‘Inside f2’);}, 3000);function f3() {console.log(‘Inside f3’);}f3();}function f4() {console.log(‘Inside f4’);}setTimeout(() => {console.log(‘Done execution’);}, 5000);f2();f4();}f1();console.log(‘Global context’);output:Inside f1Inside f3Inside f4Global contextInside f2Done execution
- নিচের কোডের আউটপুট কি?let c = 10;let a = 3;let b = 9;function timesTen(x,y,z) {return x+y+z;}let d = timesTen(c,b,a);console.log(d);
- কেন এটা referenceError দেখাচ্ছেlet xfunction timesTen(a) {x = 10;return a * 10;}let y = timesTen(x);console.log(y);
- কিভাবে এই কোড সঠিক উত্তর দিতে পারেvar zfunction timesTen(a) {z = 10;return a * 10;}let res = timesTen(z);console.log(res);
- কোডটি চালানোর আগে কনসোলে কী দেখানো হচ্ছে তা খুঁজে বের করার চেষ্টা করুন
- কোডটি চালানোর আগে কনসোলে কী দেখানো হচ্ছে তা খুঁজে বের করার চেষ্টা করুন