변수란 무엇인가? 왜 필요한가?
메모리
컴퓨터는 CPU를 사용해 연산하고, 메모리를 사용해 데이터를 기억한다.
- 메모리는 데이터를 저장할 수있는 메모리 셀의 집합체 이다.
- 메모리셀 하나의 크기는 1바이트, 각 셀은 고유의 메모리 주소를 갖는다.
- 메모리 주소는 메모리 공간의 위치를 나타내며, 0 부터 시작해서 메모리의 크기만큼 정수로 표현된다.
- 컴퓨터는 모든 데이터를 2진수로 처리하기에, 메모리에 저장되는 데이터는 데이터의 종류와 상관없이 모두 2진수로 저장된다.
프로그래밍 언어의 매커니즘
- 메모리 주소를 통해 값에 직접 접근하는것은 치명적 오류를 발생시킬 우려가 있기에,
- 프로그래밍 언어는 기억하고 싶은 값을 메모리에 저장하고, 저장된 값을 읽어 들여 재사용하기 위해 변수라는 매커니즘을 제공한다.
변수
정의: 하나의 값을 저장하기 위해 확보한 메모리 공간 자체, 또는 그 메모리 공간을 식별하기 위해 붙인 이름
- 결국 변수는 프로그래밍 언어에서 값을 저장하고 참조하는 메커니즘으로, 값의 위치를 가리키는 상징적인 이름이다.
- 변수는 프로그래밍 언어의 컴파일러 또는 인터프리터에 의해 값이 저장된 메모리 공간의 주소로 치환되어 실행된다.
- 즉 개발자는 메모리 주소를 통해 값을 저장하고 참조할 필요가 없고 변수를 통해 안전하게 값에 접근한다.
할당(대입,저장) & 참조
- 변수 이름을 사용해 참조를 요청하면 자바스크립트 엔진은 변수 이름과 매핑된 메모리 주소를 통해 메모리 공간에 접근해서 저장된 값을 반환한다.
식별자
어떤 값을 구별해서 식별할 수 있는 고유한 이름을 말한다.
식별자
- 값은 메모리 공간에 저장되어있고, 식별자는 메모리 공간에 저장되어 있는 어떤값을 구별해서 식별해내야한다.
- 따라서 식별자는 어떤 값이 저장되어있는 메모리 주소를 기억(저장) 해야한다.
- 식별자는 값이 저장되어 잇는 메모리 주소와 매핑 관계를 맺으며, 이 매핑 정보도 메모리에 저장되어야 한다.
- 즉, 식별자는 값이 아니라 사실 메모리 주소를 기억하고 있다.
변수 선언
변수를 선언하려면 반드시 선언이 필요하다.
변수 선언하기
- 선언단계 : 변수 이름을 등록해서 자바스크립트 엔진에 변수의 존재를 알린다.
- 초기화 단계
- 변수가 선언된 이후로 최초로 값을 할당하는것
- 값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화한다.
변수 이름이 등록되는곳
- 변수 이름을 비롯한 모든 식별자는 실행 컨텍스트에 등록된다. 실행 컨텍스트는 자바스크립트 엔진이 소스코드를 평가하고 실행하기 위해 필요한 환경을 제공하고 코드의 실행 결과를 실제로 관리하는 영역이다.
- 자바스크립트 엔진은 실행 컨텍스트를 통해 식별자와 스코프를 관리한다.
변수 선언 키워드 (var의 단점 보완을 위해 let,const가 ES6에서 도입)
- var
- 선언 단계와 초기화 단계가 동시에 진행된다.
- 초기화 단계를 거치지 않으면 확보된 메모리 공간에는 이전의 다른 애플리케이션이 사용했던 값이 남아있을 수 있다. → garbage Value
- var는 암묵적으로 초기화를 수행하므로 안전하다.
var score
- let
- const
변수 선언의 실행 시점과 변수 호이스팅
평가 과정
- 변수 선언은 소스코드가 한 줄씩 순차적으로 실행되는 시점(런타임) 이 아니라 그 이전 단계에서 먼저 실행(평가 과정)된다.
- 자바스크립트 엔진은 런타임 전에 평가과정을 거쳐 소스코드를 실행하기 위한 준비를 한다.
- 이때 변수 선언을 포함한 모든 선언문(변수, 함수 선언문)을 소스코드에서 찾아내 먼저 실행한다.
- 평가 과정이 끝나면 비로소 선언문을 제외하고 런타임이 동작한다.
호이스팅
- 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징을 변수 호이스팅 이라고 한다.
값의 할당
변수에 값의 할당의 시점
변수 선언은 런타임 이전 평가과정에서 일어나지만, 값의 할당은 소스코드가 순차적으로 실행되는 시점인 런타임에 실행된다.
값의 재할당
재할당: 이미 값이 할당되어 있는 변수에 새로운 값을 또다시 할당하는 것
엄밀히 말하자면 변수의 초기화도 사실은 재할당이다.
값을 재할당 할수 있기에 변수라고 한다.
만약 변수에 저장된 값을 변경할 수 없다면 이는 변수가 아니라 상수라고 한다.
- 변수의 재할당 또한 기존 메모리공간에 재할당 값을 새롭게 저장하는것이 아니라 새로운 메모리 공간을 확보하고 그 메모리 공간에 새로운 재할당 값을 저장한다.

- 그럼 어떤 식별자와도 연결되어있지 않은 undefined와 80은 어떻게 될까? → 더이상 사용되지 않는 메모리
- 이런 불필요한 값들은 가비지 콜렉터에 의해 메모리에서 자동 해제된다.
- 가비지 콜렉터
- 애플리케이션이 할당한 메모리 공간을 주기적으로 검사하여 더이상 사용되지 않는 메모리를 해제하는 기능을 말한다.
- 자바스크립트는 가비지 콜렉터를 내장하고 있는 매니지드 언어로서 이를 이용해 메모리 누수를 방지한다.

식별자 네이밍 규칭
식별자는 아래와 같은 네
이밍 규칙을 준수해야한다.
- 식별자는 특수문자를 제외한 문자, 숫자, _ , $를 포함할 수 있다.
- 식별자는 특수문자를 제외한 문자, _, $로 시작해야 한다, 숫자로시작하는것은 허용하지 않는다
- 예약어( 프로그래밍 언어에서 사용되고 있거나 사용될 예정인 단어) 는 식별자로 사용할 수 없다.

네이밍 컨벤션

- 일반적으로 변수나 함수의 이름에는 카멜케이스, 생성자 함수, 클래스의 이름에는 파스칼 케이스를 사용한다.