일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- vp #vc #did #신원인증 #블록체인
- html #js #parsing
- 블록체인 #layer2 #레이어2 #이더리움스케일링
- 미쉬킨의화폐와금융 #미쉬킨 #화폐금융론 #화폐와금융 #경제학 #교양 #경제지식 #경제공부
- 자료구조 #알고리즘
- #국제채권시장 #유로본드 #유로커런시 #유로달러 #외국채 #금융중개기관 #간접금융 #거래비용#다우존스공업평균지수 #나스닥종합지수 #FTSE100 #DAX #CAC40 #straittimes #항생지수 #거래비용 #유동성 #위
- 페이스북유니버시티 #마케팅교육 #마케팅캠프
- #경제상식 #화폐 #금융 #화폐금융론 #경제학 #경제기본 #경제지식 #경제근육 #투자지식 #경제공부 #경제학전공 #금융이란 #화폐란 #금융시장 #금융시장역할 #화폐역할 #화폐역기능 #금융역기능 #
- Today
- Total
평행우주 : world 1
[JS] 변수 hoisting과 값의 할당 본문
호이스팅에 대해 공부하다가 변수참조 코드가 변수 선언문 앞에 있을 때 undefined 가 뜨는 것을 보고,
그렇다면 변수 값 할당이 변수 선언문 앞에 있을 때는 어떠할지 궁금해졌다.
변수 선언 실행 시점과 변수 호이스팅
console.log(js); // undefined 변수 참조 코드
let js; // 변수 선언
변수 선언보다 변수 참조 코드가 먼저 나온 경우, referenceError가 뜨지 않고 undefined가 뜬다.
이 결과를 이해하기 위해서는
1) 변수 선언 수행 단계 2) 호이스팅 에 대한 이해가 필요하다.
1) 변수 선언 수행 단계
자바스크립트 엔진은 변수 선언을 2단계에 거쳐 수행한다
- 선언 단계 : 변수 이름을 등록해 자바스크립트 엔진에 변수의 존재를 알린다
- 초기화 단계 : 값을 저장하기 위한 메모리 공간을 확보하고 암묵적으로 undefined를 할당해 초기화한다
+) 변수 선언 시 undefined 를 할당해 초기화 하는 이유?
초기화 단계를 거치지 않을 시, 확보된 메모리 공간에 이전에 사용했던 값(garbage value)이 남아 있는 경우가 생길 수 있다.
다음과 같은 경우, 메모리 공간 확보 시 곧바로 변수 값을 참조하면 쓰레기 값이 나올 수 있다.
자바스크립트의 암묵적 초기화는 이러한 문제점을 예방한다.
2)호이스팅
컴퓨터는 코드를 기본적으로 위에서 아래로, 왼쪽에서 오른쪽으로 순차적으로 실행한다.
호이스팅은 이에 대한 예외로, 호이스팅 되는 대상은 그 위치가 어디에 있건 상관없이, 코드의 선두로 끌어올린 것처럼 동작하게 된다.
자바스크립트 엔진은 런타임(소스코드를 순차적으로 실행하는 것) 이전에 소스코드 평가 과정을 거치게 되는데,
모든 선언문(변수선언, 함수선언, class키워드 선언 등)을 이때 먼저 실행한다.
즉 호이스팅된 선언문은 런타임 이전에 실행한다.
값의 할당
js = 'love'; // 값의 할당
let js; // 변수 선언
console.log(js); // undefined 변수 참조
다음과 같은 경우 왜 변수 참조시 위에서 할당한 값이 나오지 않을까?
그 이유는 다음과 같다.
1. 기본적으로 모든 코드는 순차적으로 실행된다.
2. 호이스팅 되는 것은 변수에 관한 모든 것이 아닌 '변수 선언문'이다.
따라서 호이스팅 되는 것은 '변수 값의 할당'이 아닌 오직 '변수 선언문'이기 때문에 다음과 같은 결과값이 나오게 된다.
'텃밭 2 : FE > JavaScript' 카테고리의 다른 글
[JS] 익명함수란? (0) | 2022.01.16 |
---|---|
[용어정리] 값, 문, 표현식에 대하여 (0) | 2022.01.08 |
[JS] const 에 object를 선언하는 경우 (0) | 2022.01.06 |
[JS] DOM으로 HTML 조작하기 (CRUD+A) (0) | 2022.01.05 |
[JS] DOM 기초 이해하기 (0) | 2022.01.05 |