[모던 자바스크립트 Deep Dive] 4장 변수

2025. 3. 16. 16:15·Study/JavaScript
반응형

이웅모, 위키북스


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

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

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

사용자의 직접적인 메모리 제어(메모리 주소를 통해 값 접근) 비허용

→ 운영체제에 따른 오류, 코드가 실행될 때 값이 저장될 메모리 주소 결정으로 미리 알 수 없기 때문

→ 변수의 필요성

 

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

 

4.2 식별자

식별자: 어떤 값을 구별해서 식별할 수 있는 고유한 이름. 값이 아니라 메모리 주소를 기억하고 있어, 이 주소를 통해 메모리 공간에 저장된 값에 접근할 수 있는 것이다.

변수, 함수, 클래스 등 메모리 상에 존재하는 어떤 값을 식별할 수 있는 이름은 모두 식별자다. (네이밍 규칙 준수)

선언에 의해 자바스크립트 엔진에 식별자의 존재를 알린다.

 

4.3 변수 선언

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

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

(var 키워드만 있었으나, 함수 레벨 스코프만 지원된다는 심각한 단점 때문에 let, const가 등장)

 

undefined: 자바스크립트에서 제공하는 원시 타입의 값으로, 변수 선언 후 값을 할당하지 않으면 확보된 메모리 공간을 비워놓지 않고 undefined 값이 암묵적으로 할당되어 초기화되어 쓰레기 값을 참조하는 위험으로부터 안전하다.

 

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

 

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

변수 호이스팅

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

자바스크립트 엔진은 소스코드의 평가 과정을 거치면서 변수 선언을 포함한 모든 선언문을 소스코드에서 찾아 먼저 실행하고 나서, 런타임에 모든 선언문을 제외하고 소스코드를 한 줄씩 순차적으로 실행한다.

→ 변수 선언이 소스코드의 어디에 위치하는지와 상관없이 어디서든지 변수 참조 가능

 

4.5 값의 할당

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

값을 할당하면 이전 초기 값 undefined가 저장되어 있던 메모리 공간이 아닌, 새로운 메모리 공간을 확보하고 그곳에 할당 값을 저장한다.

 

4.6 값의 재할당

현재 변수에 저장된 값을 버리고 새로운 값을 저장하는 것.

변수에 저장된 값을 변경할 수 없다면 상수(constant)이다. (값을 단 한 번만 할당할 수 있는 변수)

처음 값을 할당할 때와 마찬가지로, 새로운 메모리 공간을 확보해 값을 저장한다.

→ 어떤 식별자와도 연결되지 않은 불필요한 값들은 가비지 콜렉터에 의해 메모리에서 자동 해제된다. (시기 예측은 불허)

자바스크립트는 가비지 콜렉터를 내장하고 있는 매니지드 언어로서 메모리 누수를 방지한다.

 

4.7 식별자 네이밍 규칙

  •  특수문자를 제외한 문자(대소문자 구분), 숫자, 언더스코어, 달러 기호 포함 가능
  • 숫자로 시작할 수 없음
  • 예약어는 식별자로 사용할 수 없음

변수 이름은 주석의 필요 없이 의미를 명확히 표현해 가독성을 높여야 한다.

 

네이밍 컨벤션(명명 규칙)

1. 카멜 케이스: firstName (변수, 함수 이름 권장)

2. 스네이크 케이스: first_name

3. 파스칼 케이스: FirstName (생성자 함수, 클래스 이름 권장)

4. 헝가리언 케이스: strFirstName, $elem, obserbavle$

반응형

'Study > JavaScript' 카테고리의 다른 글

[모던 자바스크립트 Deep Dive] 6장 데이터 타입  (1) 2025.03.19
[모던 자바스크립트 Deep Dive] 5장 표현식과 문  (1) 2025.03.16
[모던 자바스크립트 Deep Dive] 3장 자바스크립트 개발 환경과 실행 방법  (1) 2025.03.15
[모던 자바스크립트 Deep Dive] 2장 자바스크립트란?  (4) 2025.03.14
[모던 자바스크립트 Deep Dive] 1장 프로그래밍  (1) 2025.03.13
'Study/JavaScript' 카테고리의 다른 글
  • [모던 자바스크립트 Deep Dive] 6장 데이터 타입
  • [모던 자바스크립트 Deep Dive] 5장 표현식과 문
  • [모던 자바스크립트 Deep Dive] 3장 자바스크립트 개발 환경과 실행 방법
  • [모던 자바스크립트 Deep Dive] 2장 자바스크립트란?
harchiving
harchiving
Computer Science Engineering, undergraduate student
  • harchiving
    harchiving
    harchiving
  • 전체
    오늘
    어제
    • 분류 전체보기 (14)
      • Study (14)
        • JavaScript (6)
        • OS (5)
        • DateBase (3)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Datebase
    모던자바스크립트딥다이브
    DB
    OS
    OperatingSystem
    js
    데이터베이스
    FE
    데이터모델
    DATABASE
    CS
    javascript
    프론트엔드
    프로그래밍
    공룡책
    자바스크립트
    operatingsystemconcepts
    운영체제
    SQL
    데이터베이스개론
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.3
harchiving
[모던 자바스크립트 Deep Dive] 4장 변수
상단으로

티스토리툴바