모던 자바스크립트 Deep Dive_변수

최정석·2023년 2월 13일
0
post-thumbnail

변수란?

  • 프로그래밍 언어에서 데이터를 관리하기 위한 핵심 개념이다.
  • 아무리 복잡한 애플리케이션이라 해도 데이터를 입력받아 처리하고 그 결과를 출력하는 것이 전부다.
  • 컴퓨터는 CPU를 사용해 연산하고, 메모리를 사용해 데이터를 기억한다.
  • 메모리 주소를 통해 값에 직접 접근하는 것은 치명적 오류를 발생시킬 가능성이 매우 높다.
  • 자바스크립트는 개발자의 직접적인 메모리 제어를 허용하지 않는다.
  • 변수는 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 의미한다.
  • 여러 개의 값을 저장하려면 여러개의 변수를 사용해야 한다. 단, 배열이나 객체같은 자료구조를 사용하면 여러개의 값을 그룹화해서 하나의 값처럼 사용할 수 있다.

식별자란?

  • 식별자는 어떤 값을 구별해서 식별할 수 있는 고유한 이름을 말한다. (변수 이름)
  • 식별자는 값이 아니라 메모리 주소를 기억하고 있다.

변수 선언이란?

  • 값을 저장하기 위한 메모리 공간을 확보하고 변수 이름과 확보된 메모리 공간의 주소를 연결해서 값을 저장할 수 있게 준비하는 것이다.
  • 변수를 사용하려면 반드시 선언이 필요하다.
  • var, let, const를 사용한다.
  • ES6에서 let과 const가 도입되기 전까지 var는 자바스크립트에서 변수를 선언할 수 있는 유일한 키워드였다.
  • 변수를 사용하기 위해선 반드시 선언이 필요하다.
  • 변수뿐만 아니라 모든 식별자(함수, 클래스)가 그렇다.
  • 만약 선언하지 않은 식별자에 접근하면 레퍼런스 에러가 발생한다.

변수 var

var 키워드는 여러 단점이 있다. 가장 대표적인 것이 블록 레벨 스코프가 아닌 함수 레벨 스코프를 지원한다는 것이다. 이로 인해 의도치 않게 전역 변수가 선언되어 심각한 부작용이 발생하기도 한다.

  • var은 선언과 동시에 초기화가 진행된다.
  • var 키워드로 선언한 변수는 어떠한 값을 할당하지 않아도 undefined라는 값을 갖는다.

변수 선언의 실행 시점

  • 자바스크립트 엔진은 소스코드를 한 줄씩 순차적으로 실행하기에 앞서 먼저 소스코드의 평가 과정을 거치면서 소스코드를 실행하기 위한 준비를 한다.
  • 소스코드 실행을 위한 준비 단계인 소스코드 평과 과정에서 자바스크립트 엔진은 변수 선언을 포함한 모든 선언문을 소스코드에서 찾아내 먼저 실행한다.
  • 평가 과정이 끝나면 비로소 변수 선언을 포함한 모든 선언문을 제외하고 소스코드를 한 줄씩 순차적으로 실행한다.

호이스팅

  • 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징
  • 변수 선언뿐 아니라 var, let, const, function, class 키워드를 사용해서 선언하는 모든 식별자는 호이스팅된다.
  • 모든 선언문은 런타임 이전 단계에서 먼저 실행되기 때문이다.

값의 할당

  • 변수 선언은 소스코드가 순차적으로 실행되는 시점인 런타임 이전에 먼저 실행되지만 값의 할당은 소스코드가 순차적으로 실행되는 시점인 런타임에 실행된다.

const 키워드

  • ES6에 도입된 const 키워드를 사용해 선언한 변수는 재할당이 금지된다.
  • const 키워드를 사용하면 상수를 표현할 수 있다.

0개의 댓글