JS - 실행컨텍스트 그리기

hoin_lee·2023년 10월 3일
0

TIL

목록 보기
226/236

실행컨텍스트 그려보기

const arr = [];
function f2() {
  function Bee() {   // Bee = function() { conso…}
    console.log('f2.Bee');   // → return i;
  }
  let z = 0;
  for (let i = 0; i < 2; i += 1) {
    const x = i + 1;
    z = 1;
    function Bee() {   // 실행시 <f.o>로 인정! Bee = function() { return i; }
      return i;
    }
    arr.push(Bee);
    console.log(i, Bee()); // 0, 0
  }

  console.log(arr[0] === arr[1], arr[1] === Bee, z); // false, true, 1
  console.log('f2>>', Bee()); // 1
}
f2();

직접 drow.io를 통해 그렸고 전역 평가부터 시작해서 쭉 f2()까지 이어진다

  • Global Object 가 먼저 생성된다
  • 전역 평가시 ECS에 GEC(글로벌 실행 컨텍스트)가 올라간다
  • GEC 실행을 통해 GER(글로벌 환경 레코드)가 생성된다
  • 각 내장 필드 등을 통해 DeclarativeRecord와 BindingObject가 만들어지고 참조한다







어렵긴 하겠지만 하나씩 살펴보다보면 이해하게 되니 여러번 살펴보자

profile
https://mo-i-programmers.tistory.com/

0개의 댓글