[모던 자바스크립트 딥다이브] 4장 요약 정리
04장 변수
1. 변수란 무엇일까? 왜 필요한가?
변수는 프로그래밍 언어에서 데이터를 관리하기 위한 핵심 개념이다. 사람은 계산과 기억을 모두 두뇌에서 하지만, 컴퓨터는 연산과 기억을 수행하는 부품이 나눠져 있다. 컴퓨터는 CPU를 사용해 연산하고, 메모리를 사용해 데이터를 기억한다. 메모리는 데이터를 저장할 수 있는 메모리 셀의 집합체 이다. 하나의 메모리 셀의 크기는 1바이트(8비트)이며, 컴퓨터는 메모리 셀의 크기, 즉 1바이트 단위로 데이터를 저장하거나 읽어드린다. 각 셀은 고유의 메모리 주소를 가지게 되고, 그 주소는 메모리 공간의 위치를 나타낸다. 컴퓨터는 모든 데이터를 2진수로 처리한다. 따라서 메모리에 저장되는 데이터는 종류에 상관없이 모두 2진수로 저장된다.
만약 성공적으로 연산이 끝나고 연산 결과도 메모리에 저장되었지만 그 값을 재사용할 수가 없다. 그 값을 재사용하고 싶다면 메모리 공간에 직접 접근해야하는데 그렇게 되면 치명적인 오류가 발생할 수도 있기 때문에, 자바스크립트는 개발자가 직접적으로 메모리를 제어하는 것을 허용하지 않는다. 프로그래밍 언어는 기억하고 싶은 값을 메모리에 저장하고, 그 값을 다시 읽어들여 재사용하기 위해서는 변수라는 매커니즘을 제공한다.
변수는 하나의 값을 저장하기 위해 확보된 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 말한다. 값의 위치를 가르키는 상징적인 이름이다. 메모리 공간에 저장된 값을 식별할 수 있는 고유한 이름을 '변수이름(변수명)'이라 하고, 변수에 저장된 값을 '변수 값'이라 한다. 변수에 값을 저장하는 것을 '할당'이라 하고, 변수에 저장된 값을 읽어 들이는 것을 '참조'라 한다.
2. 식별자
변수 이름을 '식별자'라고도 한다. 식별자는 어떤 값을 구별해서 식별할 수 있는 고유한 이름을 말한다. 식별자는 값을 기억하는 것이 아니라 메모리 주소를 기억한다. 즉, 식별자는 메모리 주소에 붙인 이름이라고 할 수 있다. 식별자라는 용어는 변수 이름에만 국한되어 사용하지 않는다. 변수, 함수, 클래스 등의 이름은 모두 식별자다. 메모리 상에 존재하는 어떤 값을 식별할 수 있는 이름은 모두 식별자라고 부른다.
식별자는 네이밍 규칙을 준수해야하며, 선언에 의해 자바스크립트 엔진에 식별자의 존재를 알린다.
3. 변수 선언
변수 선언은 변수를 생성하는 것을 말한다. 좀 더 자세히 말하면 메모리 공간을 확보하고 변수의 이름과 확보된 메모리 공간의 주소를 연결하여 값을 저장할 수 있게 하는 것이다. 변수 선언에 의해 확보된 공간은 확보가 해제 되기 전까지 누구도 공간을 사용할 수 없도록 보호되므로 안전하게 사용할 수 있다.
변수를 사용하려면 반드시 선언이 필요하다. 변수를 선언할때는 var, let, const 키워드를 사용한다.
var score
변수 이름을 등록함으로써 값을 저장할 메모리 공간을 확보한다. 아직 변수에 값을 할당하지 않았다. 메모리 공간은 값이 없으니 비어있을 것으로 생각할 수 있으나 undefined라는 값이 암묵적으로 할당되어 초기화된다.
자바스크립트 엔진은 변수 선언을 선언단계, 초기화 단계(undefined 할당)에 거쳐 수행한다.
var 키워드는 선언단계와 초기화 단계가 동시에 진행된다. 만약 초기화 단계를 거치지 않으면 확보된 메모리 공간에는 이전 사용 값이 남아 있을 수 있다. 이러한 값을 쓰레기 값(garbaage value)라고 한다. 변수뿐 아니라 모든 식별자가 선언이 반드시 필요하다. 선언하지 않은 식별 자에 접근하면 참조에러가 발생하게 된다.
변수 이름은 어디에 등록될까?
변수 이름을 비롯한 모든 식별자는 실행 컨텍스트에 등록된다. 자바스크립트는 실행 컨텍스트를 통해 식별자와 스코프를 관리한다. 변수 이름과 변수 값은 실행 컨텍스트 내에서 객체로 등록되어 관리된다.
4. 변수 선언의 실행 시점과 변수 호이스팅
변수 선언은 소스코드가 한 줄씩 순차적으로 실행되는 시점이 아니라, 즉 런타임이 아니라 그 이전 단계에서 먼저 실행된다. 자바스크립트 엔진은 코드를 한줄씩 순차적으로 실행하기 이전에 평가과정을 거치게 된다. 평가과정에서 변수 선언을 포함한 모든 선언문을 찾아 먼저 실행한다. 즉 변수 선언이 소스 코드의 어디에 있든 다른 코드보다 먼저 실행되게 된다. 변수 선언문이 선두로 끌어 올려진 것 처럼 동작하는 자바스크립트의 고유한 특징을 호이스팅이라고 한다. 모든 식별자는 호이스팅 된다.
5. 값의 할당
변수에 값을 할당 할때는 할당 연산자 = 를 사용한다. 할당 연산자의 우변이 값이 된다.
var score // 변수 선언
score = 80 // 값의 할당
변수 선언과 값의 할당을 하나의 문으로 단축하여 표현할 수도 있다.
var score = 80 // 변수 선언과 값의 할당
단축 표현 하더라도 변수 선언과 값의 할당은 2개의 문으로 나누어 각각 실행한다.
변수 선언은 위에 말한 것처럼 런타임 이전에 평가 과정에서 실행되고, 값의 할당은 런타임에서 실행된다.
변수에 값을 할당할 때는 이전 값 undefined가 저장되어 있던 메모리 공간을 지우고 그 공간에 80이라는 값을 저장하는 것이 아니라 새로운 메모리 공간을 확보하고 그곳에 80을 저장한다.
6. 값의 재할당
재할당이란 이미 값이 할당되어 있는 변수에 새로운 값을 또다시 할당하는 것이다. 만약 값 을 재할당 할수 없 으면 변수가 아니라 상수이다.
재할당 시에도 80이라는 숫자를 지우고 그 곳에 새로운 값을 저장하는 것이 아니라 새로운 메모리 공간을 확보하여 새로운 값을 저장한다.
이때 사용하지 않게 되는 undefined와 80의 메모리는 가비지 콜렉터에 의해 메모리에서 자동 해제 된다. 단 언제 해제되는 지는 알 수 없다.
7. 식별자 네이밍 규칙
- 식별자는 특수문자를 제외한 문자, 숫자, 언더스코어(_), 달러 기호($)를 포함할 수 있다.
- 단 식별자는 문자, 언더스코어(_), 달러 기호($)로 시작해야한다. 숫자는 안됨
- 예약어는 식별자로 사용할 수 없다.
- 대소문자를 구별한다.
- 존재 목적을 쉽게 이해할 수 있도록 의미를 명확히 표현해야한다.
- 변수나 함수에는 카멜케이스 사용 (firstName)
- 클래스 이름에는 파스칼 케이스 사용 (FirstName)