코딩을 쉽게 해보자

[Deep Dive] 4장 - 변수 본문

JavaScript

[Deep Dive] 4장 - 변수

꿀단지코딩 2022. 8. 16. 17:22

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

10 + 20

컴퓨터는 CPU를 사용해 연산하고, 메모리를 사용해 데이터를 기억한다.

메모리는 데이터를 저장할 수 있는 메모리 셀의 집합체이다.

메모리 셀 하나의 크기는 1바이트(8비트)이며 컴퓨터는 메모리 셀의 크기, 즉 1 바이트 단위로 데이터를 저장하거나 읽어들인다.

연산 결과 30을 재사용해야하는 경우가 있는데 연산 결과 30이 저장된 메모리 공간에 직접 접근하는 것은 큰 오류가 발생할 수 있고 메모리 주소는 코드가 실행될 때 메모리의 상황에 따라 임의로 결정되기에 올바른 방법이 아니다.

이를 위해 변수라는 메커니즘을 사용한다.

 

변수

하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름
즉, 값의 위치를 상징적인 이름

변수에 값을 저장하는 것을 할당assignment(대입, 저장)이라 하고

변수에 저장된 값을 읽어 들이는 것을 참조(reference)라고 한다.

 

식별자

변수 이름을 식별자(identifier)라고도 한다.

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

식별자는 값이 아니라 메모리 주소를 기억하고 있다.

식별자라는 용어는 변수 이름에만 국한해서 사용하지 않고

변수, 함수, 클래스 등의 이름은 모두 식별자다.

메모리 상에 존재하는 어떤 값을 식별할 수 있는 이름은 모두 식별자라고 부른다.

 

변수 선언

변수를 사용하려면 반드시 선언이 필요하다. 변수를 선언할 때는 var, let, const 키워드를 사용한다.

var score;

변수 선언 이후 변수에 값을 할당하지 않았다. 확보된 메모리 공간에는 자바스크립트 엔진에 의해 undefined라는 값이 암묵적으로 할당되어 초기화된다.

 

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

1. 선언 단계

변수 이름을 등록해서 자바스크립트 엔진에 변수의 존재를 알린다.

2. 초기화 단계

값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화한다.

 

var 키워드를 사용한 변수 선언은 선언 단계와 초기화 단계가 동시에 진행된다.

선언하지 않은 식별자에 접근하면 ReferenceError가 발생한다.

 

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

console.log(error) // undefined
var score; /// 변수 선언문

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

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

 

변수 호이스팅

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

 

변수 선언뿐 아니라 var, let, const, function, function*, class 키워드를 사용해서 선언하는 모든 식별자(변수, 함수, 클래스 등)는 호이스팅 된다.

 

값의 할당(assignment)

변수 선언은 소스코드가 순차적으로 실행되는 시점인 런타임 이전에 먼저 실행되지만

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

 

값의 재할당

이미 값이 할당되어 있는 변수에 새로운 값을 또다시 할당하는 것

var 키워드 변수는 선언과 동시에 undefined로 초기화 때문에 엄밀히 말하면 처음으로 값을 할당하는 것도 사실은 재할당이다.

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

상수는 한 번만 할당할 수 있는 변수다.

 

어떤 변수도 값으로 갖고 있지않는 불필요한 값들은 가비지 콜렉터에 의해 메모리에서 자동 해제된다.

단, 메모리에서 언제 해제될지는 예측할 수 없다.

가비지 콜렉터는 애플레키에션이 할당한 메모리 공간을 주기적으로 검사, 더 이상 사용되지 않는 메모리를 해제하는 기능을 말한다.
즉, 어떤 식별자도 참조하지 않는 메모리 공간을 의미하는데 자바스크립트는 가비지 콜렉터를 내장하고 있는 매니지드 언어로서 가비지 콜렉터를 통해 메모리 누수를 방지한다.

식별자 네이밍 규칙

  • 식별자는 특수문자를 제외한 문자, 숫자, 언더스코어(_), 달러 기호($)를 포함할 수 있다.
  • 단, 식별자는 특수문자를 제외한 문자, 언더스코어(_), 달러 기호($)로 시작해야 한다, 숫자로 시작하는 것은 허용하지 않는다.
  • 예약어는 식별자로 사용할 수 없다.
    • ex) await, continue, new ....
  • 네이빙 컨벤션
    • 카멜 케이스
    • 스네이크 케이스
    • 파스칼 케이스

변수, 함수의 이름에는 카멜 케이스

생성자 함수, 클래스의 이름에는 파스칼 케이스를 주로 사용한다.

'JavaScript' 카테고리의 다른 글

[Deep Dive] 6장 - 데이터 타입  (0) 2022.08.18
[Deep Dive] 5장 - 표현식과 문  (0) 2022.08.17
[Deep Dive] 1장~ 3장  (0) 2022.08.16
이벤트 루프, 콜 스택, 태스크 큐  (0) 2022.05.29
this란?  (0) 2022.05.27