변수 개요
변수는 하나의 값을 저장하기 위해 확보한 메모리 공간, 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 말한다. 프로그래밍 언어에서 값을 저장하고 참조하는 메커니즘이다.
- 변수 이름: 메모리 공간에 저장된 값을 식별할 수 있는 고유한 이름
- 할당: 변수에 값을 저장하는 것
- 참조: 변수에 저장된 값을 읽어들이는 것
식별자
식별자란 어떤 값을 구별해서 식별할 수 있는 고유한 이름을 의미하며, 변수 이름을 식별자라고도 한다. 값은 메모리 공간에 저장되어있기에 식별자는 메모리에 저장된 어떤 값을 구별해서 식별해내야 한다. 그렇기에 식별자는 어떤 값이 저장된 “메모리 주소”를 기억해야 한다.
변수, 함수, 클래스 등 이름은 모두 식별자이며 이러한 식별자는 네이밍 규칙을 준수해야 한다.
식별자 네이밍
식별자 네이밍 규칙은 다음과 같다.
- 식별자는 특수문자를 제외한 문자, 숫자, 언더스코어(), 달러 기호($)를 포함할 수 있다.
- 단, 식별자는 특수문자를 제외한 문자, 언더스코어(), 달러 기호($)로 시작해야 한다. 숫자로 시작하는 것은 허용하지 않는다.
- 예약어는 식별자로 사용할 수 없다. (예약어: 프로그래밍 언어에서 사용되거나 사용될 예정인 단어)
네이밍 컨벤션
네이밍 컨벤션이란 하나 이상의 영어 단어로 구성된 식별자를 만들 때 가독성 좋게 단어를 구분하기 휘해 정한 규칙을 말한다. 일관성을 유지하면서 네이밍 컨벤션을 사용해야 한다.
자바스크립트에서는 일반적으로 변수나 함수에 "카멜 케이스"를 사용하고, 생성자 함수, 클래스 이름에는 "파스칼 케이스"를 사용한다. 코드의 가독성을 높이려면 카멜 케이스와 파스칼 케이스를 따르는 것이 유용하다.
- 카멜 케이스 (camelCase)
- 스네이크 케이스 (snake_case)
- 파스칼 케이스 (PascalCase)
- 헝가리안 케이스 (typeHungarianCase)
변수 선언
변수를 사용하기 위해서는 먼저 변수를 선언해야 하는데, 변수를 선언하기 위해서는 var, let, const 키워드를 사용한다. (그런데 var, let, const 키워드들 중 var 키워드는 여러 단점이 있다. 이는 추후에 알아보도록 하겠다.) var, let, const 키워드들을 통해 메모리 공간을 확보하고 변수명과 메모리 주소 연결한 후 값을 저장하여 변수를 생성하는 것이다. 만약 변수를 선언하지 않고 식별자에 접근하는 경우 참조 에러(ReferenceError)가 발생하게 된다.
순차적으로 각 과정을 살펴보도록 하겠다.
- 변수 이름을 등록하고 저장할 메모리 공간을 확보한다. (var score;)
- 변수 선언을 하고 값을 할당하지 않았더라도 변수 선언으로 확보된 메모리 공간에는 자동으로 “undefined”라는 값이 할당되어 초기화된다. (만약 초기화가 되지 않으면 쓰레기 값이 나올 수 있어 프로그램이 비정상적으로 실행될 수 있다.)
자바스크립트는 소스코드를 한 줄씩 순차적으로 실행하기 전, 소스코드의 평가 과정을 거치며 코드 실행 준비를 하는데, 이때 평가 과정에서 변수 선언, 함수 선언 등 모든 선언문을 미리 찾아내어 실행한다. 그 후 평가 과정이 끝나면 모든 선언문을 “제외”하고 소스코드를 한 줄씩 순차적으로 실행한다.
변수 호이스팅
다음의 코드를 보면 뭔가 이상한 점을 발견할 수 있다. score 식별자가 미리 사용되고, 그 후 변수로 사용되는 다음의 코드는 오류없이 진행된다. 이것이 바로 자바스크립트가 소스코드 실행 전(런타임 이전)에 먼저 변수 선언이 진행됐다는 것이다.
console.log(score); // undefined
var score; // 변수 선언
위의 코드를 통해 알 수 있듯, 자바스크립트에서는 변수 선언이 소스코드가 순차적으로 실행되는 런타임 이전 단계에서 먼저 실행된다. 이를 "변수 호이스팅 (Variable Hoisting)"이라고 한다. 변수 뿐만 아니라 var, let, const, function, fuction *, class 다음의 키워드를 사용하여 선언하는 모든 식별자는 호이스팅된다.
값의 할당과 값의 재할당
변수에 값을 할당할 때는 할당 연산자 =를 사용한다. 우변의 값을 좌변의 변수에 할당하는 것이다. 이때 주의할 것은 "변수 선언은 런타임 이전에 먼저 실행된다." 그러나, "값의 할당은 소스코드가 순차적으로 실행되는 시점인 런타임에 실행된다."는 것이다.
console.log(score); // undefined
var score; // 1. 변수 선언
score = 90; // 2. 값 할당
console.log(score); // 90
값의 재할당은 현재 변수에 저장된 값을 버리고 새로운 값을 저장하는 것이다. 즉, 변수에 저장된 값을 다른 값으로 변경하기에 "변수"이다. 값을 재할당할 수 없어서 변수에 저장된 값을 변경할 수 없다면 그것은 변수가 아니라 상수(const)이다.
var height = 169; // 변수 선언과 값의 할당
height = 171; // 값의 재할당
래퍼런스(Reference)
https://velog.io/@power0080/JavaScript%EB%B3%80%EC%88%98-%EC%84%A0%EC%96%B8
https://www.yes24.com/Product/Goods/92742567