[JavaScript] 모던 자바스크립트 Deep Dive로 배우는 JS #5 표현식과 문

TIL(Today I Learned) 🧑🏻‍💻


5. 표현식과 문


5.1  값

  • 값(value)은 식(표현식, expression)이 평가(evaluate)되어 생성된 결과를 말한다.

  • 모든 값은 데이터 타입을 가지며, 메모리에 2진수, 즉 비트(bit)의 나열로 저장된다. 메모리에 저장된 값은 데이터 타입에 따라 다르게 해석될 수 있다.

  • 값은 다양한 방법으로 생성할 수 있다. 식으로 생성할 수도 있지만 가장 기본적인 방법은 리터럴을 사용하는 것이다.


5.2  리터럴

  • 리터럴(literal)은 사람이 이해할 수 있는 문자 또는 약속된 기호를 사용해 값을 생성하는 표기법(notation)을 말한다.

  • 자바스크립트 엔진은 코드가 실행되는 시점인 런타임(runtime)에 리터럴을 평가해 값을 생성한다. 즉, 리터럴은 값을 생성하기 위해 미리 약속한 표기법이라고 할 수 있다.


5.3  표현식

  • 표현식(expression)은 값으로 평가될 수 있는 문(statement)이다. 즉, 표현식이 평가되어 새로운 값을 생성하거나 기존 값을 참조한다.

  • 문법적으로 값이 위치할 수 있는 자리에는 표현식도 위치할 수 있다는 것을 의미한다.


5.4  문

  • 문(statement)은 프로그램을 구성하는 기본 단위이자 최소 실행 단위다. 문은 여러 토큰으로 구성된다.

  • 토큰(token)이란 문법적인 의미를 가지며, 문법적으로 더 이상 나눌 수 없는 코드의 기본 요소를 의미한다.

  • 문을 명령문이라고도 부른다.


5.5  세미클론과 세미클론 자동 삽입 기능

  • 세미클론(;)은 문의 종료를 나타낸다. 자바스크립트 엔진은 세미클론으로 문이 종료한 위치를 파악하고 순차적으로 하나씩 문을 실행한다.

  • 코드 블록({ ... }) 뒤에는 세미클론을 붙이지 않는다. 따라서 if문, for문, 함수 등의 코드 블록 뒤에는 세미클론을 붙이지 않는다. 이러한 코드 블록은 언제나 문의 종료를 의미하는 자체 종결성(self closing)을 갖기 때문이다.

  • 자바스크립트는 세미클론을 생략 가능하다. 세미클론 자동 삽입 기능(ASI, automatic semicolon insertion)이 암묵적으로 수행되기 때문이다.


5.6  표현식인 문과 표현식이 아닌 문

  • 표현식인 문은 값으로 평가될 수 있는 문이며, 표현식이 아닌 문은 값으로 평가될 수 없는 문을 말한다.
// 표현식이 아닌 문은 값처럼 사용할 수 없다.
var foo = var x; // SyntaxError: Unexpected token 
// 표현식인 문은 값처럼 사용할 수 있다.
var foo = x = 100;
console.log(foo); // 100
  • 표현식인 문과 표현식이 아닌 문을 구별하는 가장 간단하고 명료한 방법은 변수에 할당해 보는 것이다.

  • 크롬 개발자 도구에서 표현식이 아닌 문을 실행하면 언제나 undefined를 출력한다. 이를 완료 값이라 한다. 완료 값은 표현식의 평가 결과가 아니다.


새로운 용어 정리



참고 문헌


* 모던 자바스크립트 Deep Dive ( 자바스크립트의 기본 개념과 동작 원리 ) / 이웅모 지음

좋은 웹페이지 즐겨찾기