[목차] == 개요 == Hoisting [[자바스크립트]] 및 [[액션스크립트]] 코드를 인터프리터가 로드할 때, 변수의 정의가 그 범위에 따라 선언과 할당으로 분리되어 변수의 선언을 항상 컨텍스트 내의 최상위로 끌어올리는 것을 의미한다. 이는 오로지 변수에만 해당되는 것은 아니고 함수도 가능하며, 자바스크립트에서 함수의 호출을 첫 줄에서 하고 마지막 줄에 함수를 정의해도 문제없이 작동되도록 하는 유용한 특성이다. == 예제 == 그러나 호이스팅은 생각지도 못한 곳에서 [[버그]]를 일으키는 [[만악의 근원]]이 되기도 한다. 가령 아래와 같은 코드가 있을 경우, {{{#!syntax javascript function sum (a, b) { var x = add(a,b); return x; function add (c, d) { var result = c+d; return result; } } }}} 자바스크립트 인터프리터는 아래와 같이 읽는다. {{{#!syntax javascript function sum (a, b) { var x = undefined; function add (c, d) { var result = c+d; return result; } x = add(a,b); return x; } }}} 변수의 경우 어디서 어떻게 선언을 하더라도 항상 컨텍스트내의 최상위로 끌고올라온 뒤 'undefined'를 할당해 둔다. 이후 함수 선언을 끌고 올라오고 난 뒤 변수의 할당과 함수의 실행문을 순서대로 가져온다. 즉 호이스팅은 자바스크립트 인터프리터가 코드를 읽는 방식이며, 이를 이해해야 원치않는 'undefined'가 출력되는 것을 막을 수 있다. ECMAScript 6판에서는 var나 function declaration대신에 추가된 let이라는 예약어를 사용하면 호이스팅을 막을 수 있다. 실제 현업에서는 var 키워드는 절대로 쓰이지 않으며 99%이상의 경우 모든 함수를 무조건 const와 arrow syntax로 선언하기 때문에 최근 들어서는 사실상 크게 신경쓰지 않는 부분이 되었다. == 관련 문서 == * [[자바스크립트]] * [[액션스크립트]] * [[컴퓨터공학]] * [[나무위키 컴퓨터 프로젝트]] [[분류:프로그래밍]]