sandwe 2022. 7. 18. 20:14

변수(Variable)

하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름
var result = 10 + 20; // result: 변수 이름, 변수값: 10 + 20이 계산된 결과인 30

변수는 메모리 셀에 저장된 값의 위치를 가리키는 상징적인 이름이다. 변수는 프로그래밍 언어의 컴파일러 또는 인터프리터에 의해 값이 저장된 메모리 공간의 주소로 치환되어 실행된다.

  • 할당(Assignment) : 변수에 값을 저장하는 것
  • 참조(Reference): 변수에 저장된 값을 읽어 들이는 것
  • 변수 이름: 사람이 이해할 수 있는 언어로 값이 저장된 메모리 공간에 붙인 상징적인 이름
    변수 이름을 사용해 참조를 요청하면 자바스크립트 엔진은 변수 이름과 매핑된 메모리 주소를 통해 메모리 공간에 접근해서 저장된 값을 반환한다.

 

식별자(Identifier)

어떤 값을 구별해서 식별할 수 있는 고유한 이름

식별자는 어떤 값이 저장되어 있는 메모리 주소를 기억한다. 따라서, 식별자로 값을 구별해서 식별한다는 것은 식별자가 기억하고 있는 메모리 주소를 통해 메모리 공간에 저장된 값에 접근한다는 의미이다.

변수 외에도 메모리 상에 존재하는 함수, 클래스 등 어떤 값을 식별할 수 있는 모든 이름을 식별자라고 한다.

 

변수 선언(Declaration)

변수를 생성하는 것
값을 저장하기 위한 메모리 공간을 확보하고 변수 이름과 확보된 메모리 공간의 주소를 연결해 값을 저장할 수 있게 준비하는 것
var score;

var 키워드로 score라는 이름의 변수를 선언하였다. 자바스크립트 엔진은 변수 선언을 다음의 2단계를 거쳐 수행한다.

  1. 선언 단계: 변수 이름 (score)를 등록해 자바스크립트 엔진에 변수의 존재를 알린다.
  2. 초기화 단계: 값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화한다.

만약 초기화 단계를 거치지 않으면 확보된 메모리 공간에는 이전에 다른 애플리케이션이 사용했던 값(쓰레기 값)이 남아 있을 수 있다. 따라서 메모리 공간을 확보한 다음, 값을 할당하지 않은 상태에서 바로 변수 값을 참조하면 쓰레기 값이 나올 수 있다. var 키워드는 암묵적으로 초기화를 수행하므로 이러한 위험으로부터 안전하다. 

 

 

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

변수 호이스팅: 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징
console.log(score); // undefined
var score;

위의 예제는 변수의 참조가 선언보다 앞에 있어 인터프리터에 의해 한줄씩 실행되면서 참조 에러(Reference Error)가 발생할 것처럼 보이나 undefined가 잘 출력된다.

❓ 변수 선언은 런타임 전에 먼저 실행되기 때문에 소스코드의 어디에 위치하든지 간에 변수를 참조할 수 있게 된다.
런타임: 소스코드가 한 줄씩 순차적으로 실행되는 시점

모든 선언문은 런타임 이전 단계에서 먼저 실행되기 때문에 변수 선언뿐만 아니라 var, let, const, function, function*, class 키워드를 사용해 선언하는 모든 식별자는 호이스팅된다. 

 

 

값의 할당

값을 할당할 때는 할당 연산자(=)를 사용한다.
var score; // 변수 선언
score = 80 // 값을 할당

var score = 80; // 선언과 할당을 동시에

 

변수의 선언은 런타임 이전에 실행되지만 값의 할당은 런타임에 실행된다.

console.log(score); // undefined

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

console.log(score); // 80

위의 예제처럼 변수의 선언과 값의 할당을 하나의 문장으로 단축 표현해도 자바스크립트 엔진은 변수의 선언과 할당을 다른 단계에서 실행한다. 변수에 값을 할당할 때는 이전 값 undefined는 놔두고 새로운 메모리 공간을 확보하고 그곳에 80을 저장한다는 것을 주의해야 한다.

실제로 80이라는 값은 2진수로 저장된다.

 

 

값의 재할당

재할당: 이미 값이 할당되어 있는 변수에 새로운 값을 또다시 할당하는 것
var score = 80; // 변수 선언과 값의 할당
score = 90; // 값의 재할당

 

현재 score 변수의 값은 90이고, 이전 값 undefined와 80은 어떤 식별자와도 연결되어 있지 않은 쓰레기 값이 된다. 이러한 불필요한 값들은 가비지 콜렉터에 의해 메모리에서 자동 해제되나 언제 해제될지는 예측할 수 없다. 가비지 콜렉터를 통해 메모리 누수를 방지한다.

값을 재할당할 수 없어서 변수에 저장된 값을 변경할 수 없다면 상수(Constant)라고 한다.

 

식별자 네이밍 규칙

식별자는 다음의 네이밍 규칙을 준수해야 한다.

1️⃣ 식별자는 특수문자를 제외한 문자, 숫자, 언더스코어(_), 달러기호($)를 포함할 수 있다.
2️⃣ 단, 식별자는 특수문자를 제외한 문자, 언더스코어(_), 달러기호($)로 시작해야 한다. 숫자로 시작해서도 안된다.
3️⃣ 예약어는 식별자로 사용할 수 없다.
     예약어: 프로그래밍 언어에서 사용되고 있거나 사용될 예정인 단어
  • 변수 선언에 별도의 주석이 필요하다면 변수의 존재 목적을 명확히 드러내지 못하는 것이다.
var x = 3; // NG. x가 의미하는 바를 알 수 없다.
var score = 100; // OK. score 변수는 점수를 의미한다.
  • 네이밍 컨벤션: 하나 이상의 영어 단어로 구성된 식별자를 만들 때 가독성을 높이는 명명 규칙
// 카멜 케이스(camelCase). 주로 변수나 함수의 이름에 사용한다.
var firstName;

// 파스칼 케이스(PascalCase). 주로 생성자 함수, 클래스의 이름에 사용한다.
var FirstName;