Search

1장 변수 & 식별자

대분류
언어
서적
소분류
JS DeepDive
주요 레퍼런스
https://velog.io/@hustle-dev/%EB%AA%A8%EB%8D%98-%EC%9E%90%EB%B0%94%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%8A%B8-Deep-Dive-15%EC%9E%A5#%EB%B3%80%EC%88%98%EB%9E%80-%EB%AC%B4%EC%97%87%EC%9D%B8%EA%B0%80-%EC%99%9C-%ED%95%84%EC%9A%94%ED%95%9C%EA%B0%80
태그
변수
식별자
선언
값의 할당
네이밍 규칙
스코프
최종 편집 일시
2024/10/27 15:42
생성 일시
2024/01/24 10:23
13 more properties

변수

하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름 → 값의 위치를 가리키는 상징적인 이름
할당(대입, 저장) : 변수에 값을 저장하는 것
참조 : 변수에 저장된 값을 읽어 들이는 것
// 변수는 하나의 값을 저장하기 위한 수단이다. var userId = 1; var userName = 'Lee'; // 객체나 배열 같은 자료구조를 사용하면 여러 개의 값을 하나로 그룹화해서 하나의 값처럼 사용할 수 있다. var user = { id: 1, name: 'Lee' }; var users = [ { id: 1, name: 'Lee' }, { id: 2, name: 'Kim' } ];
JavaScript
복사

식별자

변수, 함수, 클래스 등의 이름이 모두 식별자, 선언에 의해 JS엔진에 식별자의 존재를 알림
어떤 값을 구별해서 식별할 수 있는 고유한 이름
값이 저장되어 있는 메모리 주소와 매핑 관계 - 메모리 주소 기억

변수 선언

1.
자바스크립트 엔진에 식별자의 존재를 알리는 것
2.
값을 저장하기 위한 메모리 공간을 확보하고, 변수 이름과 확보된 메모리 공간 주소를 연결해서 값을 저장할 수 있게 준비하는 것
var(함수레벨 스코프), let, const같은 키워드를 사용해서 선언
변수 이름을 등록하고 값을 저장할 메모리 공간을 확보. undefined 값이 암묵적으로 할당되어 초기화된다. undefined : js에서 제공하는 원시 타입.
변수 선언 과정
선언 단계: 런타임 전 실행 컨텍스트에서 관리하며 변수 이름을 등록해서 자바스크립트 엔진에 변수의 존재를 알린다.
초기화 단계: 값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화 한다.(초기화 하지 않으면 쓰레기 값이 남아 있을 수 있어서 이러한 위험을 방지하기 위해 암묵적으로 초기화를 수행함)
모든 식별자는 실행 컨텍스트에 등록 (식별자와 스코프 관리)
실행 컨텍스트 : JS 엔진이 소스 코드를 평가하고 실행하기 위해 필요한 환경을 제공하고 코드의 실행 결과를 실제로 관리하는 영역

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

console.log(score); // undefined var score; // ① 변수 선언 - 호이스팅 score = 80; // ② 값의 할당 console.log(score); // 80 // var score = 80; 은 var score과 score = 80으로 개별 실행된다.
JavaScript
복사
이 경우 참조에러가 발생하지 않고 undefined가 출력되는데 변수 선언이 소스코드가 한 줄씩 순차적으로 실행되는 시점, 즉 런타임이 아니라 그 이전 단계에서 먼저 실행되기 때문.
변수 호이스팅 : 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징 (var에서만 동작)

변수 네이밍

변수 : 명사형
함수 : 동사형 ex) is~, has~ (boolean 판단할 때)

값의 할당

실행 시점이 다르다
변수 선언 : 소스코드가 순차적으로 실행되는 시점인 런타임 이전에 먼저 실행
값의 할당 : 소스코드가 순차적으로 실행되는 시점인 런타임에 실행

값의 재할당

변수에 처음으로 값을 할당하는 것도 재할당
상수(Constant) : 재할당이 불가능한 변수
값을 재할당 할때 기존 공간에 새로운 값을 저장하는 것이 아닌 새로운 메모리 공간에 값을 저장하기 때문에 어떠한 식별자와도 연결되어 있지 않은 값들(더 이상 사용되지 않는 메모리)은 가비지 콜렉터에 의해 메모리에서 자동 해제된다.(가비지 콜렉터로 메모리 누수를 방지한다.)
언매니지드 언어 --> c와 같이 메모리 제어(malloc, free)를 개발자가 주도적으로 할 수 있는거
매니지드 언어 --> 개발자의 직접적인 메모리 제어를 허용하지 않음

가비지 콜렉터 (Garbage Collecter)

실행컨텍스트가 종료되어 더이상 참조할 수 없는 값들을 mark-and-sweep 이라는 알고리즘으로 루트부터 시작하여 모든 객체를 돌면서 방문할 수 없는 곳(도달 가능성 기준으로 도달하지 못한곳)을 메모리에서 삭제 실행

식별자 네이밍 규칙

구성 : 특수문자 제외 문자, 숫자, 언더스코어, 달러 기호
시작 : 특수문자 제외 문자, 언더스코어, 달러 기호
예약어는 식별자로 사용 X
네이밍 컨벤션
카멜케이스(firstName)
스네이크케이스(first_name)
파스칼 케이스(FirstName)
헝가리언 케이스 (strFirstName) : type + identifier