[모던 자바스크립트 Deep Dive] 4장 변수

수정·2022년 10월 9일
0
post-thumbnail

#1 변수란 무엇인가? 왜 필요한가?

변수는 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 말한다.

간단히 말하자면 변수는 프로그래밍 언어에서 값을 저장하고 참조하는 매커니즘으로, 값의 위치를 가리키는 상징적인 이름이다.



#2 식별자

식별자는 어떤 값을 구별해서 식별할 수 있는 고유한 이름을 말하며,
값이 아니라 메모리 주소를 기억하고 있다.
즉, 식별자는 메모리 주소에 붙인 이름이라고 할 수 있다.



#3 변수 선언

변수 선언이란 변수를 생성하는 것을 말하고, 사용하려면 반드시 선언이 필요하다. 변수를 선언할 때는 var, let, const 키워드를 사용한다.
(선언하지 않은 식별자에 접근하면 ReferemceError(참조에러)가 발생한다.)

자바스크립트 엔진은 변수 선언을 다음과 같은 2단계에 거쳐 수행한다.

  • 선언 단계 : 변수 이름을 등록해서 자바스크립트 엔진에 변수의 존재를 알린다.
  • 초기화 단계 : 값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화한다.
    ( var 키워드를 사용한 변수 선언은 선언 단계와 초기화 단계가 동시에 진행된다. )



#4 변수 선언의 실행 시점과 변수 호이스팅

console.log(score); // undefined

var score; // 변수 선언문

변수 선언문보다 변수를 참조하는 코드가 앞에 있다.
자바스크립트 코드는 인터프리터에 의해 한 줄씩 순차적으로 실행되므로 참조 에러가 발생할 것처럼 보이지만, 참조 에러가 발생하지 않고 undefined 가 출력된다.

변수 선언이 소스코드가 한 줄씩 순차적으로 실행되는 시점, 즉 런타임이 아니라 그 이전 단계에서 실행되기 때문이다.

자바스크립트 엔진은 변수 선언이 소스코드의 어디에 있든 상관없이 다른 코드보다 먼저 실행한다.

이처럼 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징을 변수 호이스팅이라 한다.



#5 값의 할당

변수에 값을 할당할 때는 할당연산자 = 를 사용한다. 할당 연산자는 우변의 값을 좌변의 변수에 할당한다.

console.log(score); // undefined

var score;  // ① 변수 선언
score = 80; // ② 값의 할당

console.log(score); // 80

값의 할당은 변수 선언과 달리 소스코드가 순차적으로 실행되는 시점인 런타임에 실행된다.



#6 값의 재할당

값의 재할당이란 이미 값이 할당되어 있는 변수에 새로운 값을 또다시 할당하는 것을 말한다.

만약 값을 재할당할 수 없어서 변수에 저장된 값을 변경할 수 없다면 변수가 아니라 상수라 한다.

const 키워드

ES6에서 도입된 const 키워드를 사용해 선언한 변수는 재할당이 금지된다. 즉, const 키워드는 단 한 번만 할당할 수 있는 변수를 선언한다. 따라서 const 키워드를 사용하면 상수를 표현할 수 있다.



#7 식별자 네이밍 규칙

  • 식별자는 특수문자를 제외한 문자, 숙자, 언더스코어(_), 달러기호($)를 포함할 수 있다.
  • 단, 식별자는 특수문자를 제외한 문자, 언더스코어(_), 달러기호($)로 시작해야한다. 숫자로 시작하는 것은 허용하지 않는다.
  • 예약어는 식별자로 사용할 수 없다.

변수 이름은 변수의 존재 목적을 쉽게 이해할 수 있도록 의미를 명확히 표현해야 한다. 좋은 변수 이름은 코드의 가독성을 높인다. 코드 전체의 가독성을 높이려면 카멜 케이스와 파스칼 케이스를 따르는 것이 유리하다.
profile
공부 기록

0개의 댓글