reading-notes

Aloysious' Codefellows Reading Notes

View the Project on GitHub

Code 301 Reading Notes

Class 10

<== Previous Lesson Next Lesson ==>

<== Home 🏠

In memory storage

Understanding the JavaScript Call Stack

//                   Last In, First Out = L I F O 

// The last function that gets pushed into the stack is the first 
// to be pop out, when the function returns.

function firstFunction(){
  throw new Error('Stack Trace Error');
}

function secondFunction(){
  firstFunction();
}

function thirdFunction(){
  secondFunction();
}

thirdFunction();

// the arrangement of the functions as a stack begins with the 
// firstFunction() (which is the last function that got into the stack, 
// and is popped out to throw the error), 

// followed by the secondFunction(), 

// and then the thirdFunction() (which is the first function that 
// gets pushed into the stack when the code is executed).

The key takeaways from the call stack are:

  1. It is single-threaded. Meaning it can only do one thing at a time.
  2. Code execution is synchronous.
  3. A function invocation creates a stack frame that occupies a temporary memory.
  4. It works as a LIFO — Last In, First Out data structure.

JavaScript error messages

Some syntax errors like sending a trailing comma when calling a function are handled without error by most recent browsers, but older ones you have to be careful.

Try to manipulate an object with some kind of length and give it an invalid length and Range Errors will show up.

EXAMPLE :

var foo= []
foo.length = foo.length -1 // Uncaught RangeError: Invalid array length

JavaScript errors reference on MDN

Reading

Additional Resources

<== Home 🏠