> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 작동 방식: 실행 컨텍스트 이해(초보자를 위한 단순화)

JavaScript 작동 방식: 실행 컨텍스트 이해(초보자를 위한 단순화)

Patricia Arquette
풀어 주다: 2024-12-06 21:14:15
원래의
534명이 탐색했습니다.

How JavaScript Works: Understanding Execution Context (Simplified for Beginners)

JavaScript는 세계에서 가장 인기 있는 프로그래밍 언어 중 하나입니다. 하지만 내부적으로는 어떻게 작동하나요? 초보자라도 이해할 수 있도록 간단한 개념과 의사코드를 사용하여 단계별로 풀어보겠습니다.


자바스크립트란 무엇인가요?

JavaScript는 브라우저(예: Chrome, Firefox, Safari) 또는 서버(Node.js와 같은 도구 사용)에서 실행되는 프로그래밍 언어입니다. 웹사이트를 대화형으로 만드는 데 사용됩니다. 브라우저에서 애니메이션, 멋진 일을 하는 버튼, 게임을 볼 때 JavaScript가 마법을 부리고 있습니다.

JavaScript의 작동 방식을 이해하려면 다음 두 가지를 이해해야 합니다.

  1. 실행 컨텍스트
  2. 콜 스택

실행 컨텍스트란 무엇인가요?

실행 컨텍스트는 JavaScript가 코드를 실행하는 데 필요한 모든 것을 보관하는 상자와 같습니다. 여기에는 다음이 포함됩니다.

  1. 변수(x = 5와 같이 저장하는 데이터)
  2. 함수(showMessage()와 같이 작업을 수행하는 코드 조각)
  3. 실행할 코드 (작성한 실제 지침)

실행 컨텍스트에는 두 가지 주요 유형이 있습니다.

  1. GEC(전역 실행 컨텍스트): 이는 JavaScript가 코드 실행을 시작하는 기본 상자입니다. 메인무대같네요.
  2. FEC(Function Execution Context): 함수가 호출될 때마다 생성되는 새로운 상자입니다. 해당 기능에 대해서만 작동합니다.

단계별 예시

다음과 같은 간단한 의사코드를 작성했다고 가정해 보세요.

// Global Code
var name = "Alex";
function greet() {
    var message = "Hello, " + name;
    return message;
}
greet();
로그인 후 복사
로그인 후 복사

JavaScript의 단계별 작업은 다음과 같습니다.


1. 전역 실행 컨텍스트 생성

프로그램이 시작되면 JavaScript가 자동으로 GEC(전역 실행 컨텍스트)를 생성합니다.

  • 메모리(가변 환경):

    • 이름 = 정의되지 않음(현재 자리 표시자)
    • Greeting = 함수 정의(greet() 코드 저장)
  • 코드 실행 단계:

    • 전역 코드를 한 줄씩 실행합니다.
    • var 이름 = "알렉스"; → 메모리 업데이트: 이름 = "Alex"
    • 만남의 인사(); → 인사 기능을 호출합니다.

2. 함수 실행 컨텍스트 생성

greet()가 호출되면 JavaScript는 Greeting을 위해 특별히 새로운 FEC(Function Execution Context)를 생성합니다.

  • 메모리(가변 환경):

    • message = 정의되지 않음(greet 내부 변수에 대한 자리 표시자)
  • 코드 실행 단계:

    • 인사 기능 실행:
    • var message = "안녕하세요, " 이름; → "Hello"와 이름("Alex")을 결합하므로 메시지 = "Hello, Alex".
    • 반환 메시지; → "Hello, Alex"를 다시 보냅니다.

3. 청소 및 반납

인사말 기능이 끝나면 해당 함수 실행 컨텍스트가 제거(삭제)됩니다. 프로그램이 전역 실행 컨텍스트로 돌아갑니다.


실행 컨텍스트는 어떻게 되나요?

JavaScript는 호출 스택을 사용하여 이러한 모든 실행 컨텍스트를 추적합니다.

콜 스택이란 무엇입니까?

호출 스택은 접시 더미와 같습니다.

  1. 전역 실행 컨텍스트는 하단(첫 번째 플레이트)에 있습니다.
  2. 함수가 호출될 때마다 함수 실행 컨텍스트가 맨 위에(새 플레이트) 추가됩니다.
  3. 함수가 끝나면 해당 컨텍스트가 제거됩니다(플레이트가 벗겨짐).

의사 코드로 시각화

JavaScript가 코드를 처리하는 방법은 다음과 같습니다.

  1. 초기 전역 코드(GEC 생성):

    // Global Code
    var name = "Alex";
    function greet() {
        var message = "Hello, " + name;
        return message;
    }
    greet();
    
    로그인 후 복사
    로그인 후 복사
  2. 전역 실행 업데이트(코드 실행):

    GEC:
      Memory: { name: undefined, greet: function }
      Code: Execute global lines
    
    로그인 후 복사
  3. 인사() 호출(FEC 생성):

    GEC:
      Memory: { name: "Alex", greet: function }
      Code: Encounters greet()
    
    로그인 후 복사
  4. greet()를 실행하고 돌아가기:

    Call Stack:
      1. GEC
      2. FEC for greet()
    FEC (greet):
      Memory: { message: undefined }
      Code: Execute function lines
    
    로그인 후 복사
  5. 실행 완료:

    FEC (greet):
      Memory: { message: "Hello, Alex" }
      Return value: "Hello, Alex"
    Call Stack after return:
      1. GEC
    
    로그인 후 복사

기억해야 할 주요 사항

  1. 실행 컨텍스트는 JavaScript가 코드를 실행하는 컨테이너와 같습니다. 모든 프로그램은 전역 실행 컨텍스트로 시작하고 각 함수는 고유한 함수 실행 컨텍스트를 갖습니다.
  2. 콜 스택은 실행 중인 항목을 추적합니다. 마지막에 추가된 것이 가장 먼저 제거되는 것입니다(LIFO: Last In, First Out).
  3. JavaScript는 기능이 완료되면 정리됩니다. 이것이 바로 함수의 메모리가 영원히 남아있지 않는 이유입니다.

이것이 왜 중요합니까?

실행 컨텍스트를 이해하면 더 나은 프로그램을 작성하는 데 도움이 됩니다.

  • 왜 어떤 곳에서는 변수를 사용할 수 있고 다른 곳에서는 사용할 수 없는 이유를 알게 될 것입니다(범위).
  • "정의되지 않은" 변수와 같은 오류를 이해하게 될 것입니다.
  • 함수가 상호 작용하는 방식과 값을 반환하는 이유를 살펴보겠습니다.

도전하세요

이 의사코드를 마음속으로 실행해 보세요.

Call Stack:
  Empty (Program Ends)
로그인 후 복사

스스로에게 물어보세요:

  1. 전역 실행 컨텍스트에는 무엇이 있나요?
  2. 곱하기()가 호출되면 어떻게 되나요?
  3. 결과의 최종 가치는 무엇인가요?

실행 컨텍스트를 마스터하면 가장 까다로운 JavaScript 문제도 해결할 수 있는 탄탄한 기반을 갖게 됩니다!

위 내용은 JavaScript 작동 방식: 실행 컨텍스트 이해(초보자를 위한 단순화)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿