Understanding the Call Stack in JS🧿🔥
Managing Function Hierarchy and Execution Order🫡
This article aims🚀 to provide a clear explanation of what the call stack is and why? it is important in JavaScript. Understanding the call stack will help you grasp how to function hierarchy and execution order function
in the JavaScript engine.
Before we delve👀 into the details, let's begin💪 by answering the below questions:
What is LIFO?
LIFO stands for "Last In, First Out," and it is a principle commonly used in data structures, including the call stack. In LIFO, the last item added to the structure is the first one to be removed.
void Bar()
{
Console.WriteLine("Bar");
}
void Foo()
{
Bar();
}
void Main()
{
Foo();
}
When the
Main()
function is called, it is added to the call stack.Inside
Main()
, theFoo()
function is called, soFoo()
is added to the stack aboveMain()
.Inside
Foo()
, theBar()
function is called, soBar()
is added to the stack aboveFoo()
.When
Bar()
finishes executing, it is removed from the stack.Control returns to
Foo()
, which then completes its execution and is removed from the stack.Finally, control returns to
Main()
, which completes its execution and is removed from the stack.
output:
Bar
When you run the code, it will start by calling the Main()
function. Inside Main()
, it calls the Foo()
function. Inside Foo()
, it calls the Bar()
function.
The execution follows these steps:
Bar()
function prints "Bar" to the console.Control returns to
Foo()
function, which then completes its execution.Finally, control returns to
Main()
function, which also completes its execution.
Therefore, the output in the console will be "Bar"
What is a call stack?
In simpler terms, the
call stack
is a mechanism that JavaScript uses to keep track of function calls. It plays a crucial role in maintaining the order in which functions are executed.
How the Call Stack Works👇:
Imagine a stack of plates🍽️, where you always place a new plate on top and remove the topmost plate when needed. Similarly, the call stack operates based on the "last in, first out" principle (LIFO). When a function is called, it is added to the top of the stack. If that function calls another function, the new function is placed on top, forming a stack of function calls. The last function added to the stack is the first one to be executed, and when a function completes its execution, it is removed from the stack.
To better understand this concept, let's consider a simple example:
function greet() {
console.log("Hello!");
}
function welcome() {
greet();
console.log("Welcome!");
}
function main() {
welcome();
console.log("Main function executed.");
}
main();
Internally,
When
main()
is called, and it is added to the call stack.Inside
main()
,welcome()
is called, sowelcome()
is added to the stack abovemain()
.Inside
welcome()
,greet()
is called, sogreet()
is added to the stack abovewelcome()
.When
greet()
finishes executing, it is removed from the stack.Control returns to
welcome()
, which then completes its execution and is removed from the stack.Finally, control returns to
main()
, which completes its execution and is removed from the stack.
output💀:
Hello!
Welcome!
Main function executed.
By observing the call stack in this example, we can see how functions are added and removed from the stack, maintaining the correct execution order.
Conclusion😭:
The key takeaways from the call stack are:
It is
single-threaded
. Meaning it can only do one thing at a time.Code execution is
synchronous
.It works as a
LIFO — Last In, First Out data structure
.
Understanding🧩 the call stack and how it handles function calls is fundamental to comprehending the flow and behaviour of your JavaScript code. It helps you ensure the correct execution🔍 order and avoid potential errors or unexpected outcomes.
Thank you for reading this article!
I hope it provided you with valuable insights on "Understanding all about call-stacks". Farewell💖, and best of luck in your endeavours!