5. 표현식과 문




개념을 이해한다는 것 === 용어를 정확히 이해하고 설명할 수 있다는 것

  • 식(표현식)이 평가(evaluate : 식을 해석해서 값을 생성하거나 참조하는 것)되어 생성된 결과
20 + 30 // 50
// 20 + 30 은 평가되어 숫자 값 50을 생성한다.

var sum = 20 + 30
// 변수에는 20 + 30 이 평가되어 생성된 숫자 값 30이 할당된다.



리터럴

  • 값을 생성하는 방법 중 하나
  • 사람이 이해할 수 있는 문자 또는 약속된 기호를 사용해 값을 생성하는 표기법
  • 정수, 부동소수점, 2진수, 8진수, 문자열, 불리언, null, 객체 리터럴 …



표현식

  • 값으로 평가될 수 있는 문(statement)
  • 표현식이 평가되면 새로운 값을 생성하거나 기존 값을 참조한다.
  • var score = 100 //100이라는 리터럴도 표현식이다.
  • 값으로 평가될 수 있는 문은 모두 표현식이다.
  • 표현식과 표현식이 평가된 값은 동치(equivalent)이다.



  • 문 : 프로그램을 구성하는 기본 단위이자 최소 실행 단위
  • 문(statement)와 표현식(expression) 구별하기
  • 문은 여러 토큰으로 구성된다.
  • 토큰 : 문법적인 의미를 가지며, 문법적으로 더 이상 나눌 수 없는 코드의 기본 요소
  • 문의 종류 : 선언문, 할당문, 조건문, 반복문 …



세미콜론과 세미콜론 자동 삽입 기능

  • 세미콜론 : 문의 종료
  • js 엔진은 세미콜론으로 문이 종료한 위치를 파악하고, 순차적으로 하나씩 문을 실행한다.
  • 문을 끝낼 때는 세미콜론을 붙여야 한다.
  • 단, 코드 블록 뒤에는 붙이지 않는다. 코드 블록은 언제나 문의 종료를 의미하는 자체 종결성을 갖기 때문
  • 문의 끝에 붙이는 세미콜론은 옵션이다. (생략 가능)
  • js 엔진이 소스코드를 해석할 때 문의 끝이라고 예측되는 지점에 세미콜론을 자동으로 붙여주는 세미콜론 자동 삽입 기능(ASI)이 암묵적으로 수행되기 때문



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

  • 표현식은 문의 일부일 수도 있고, 그 자체로 문이 될 수도 있다.
  • 문이 더 크고, 표현식이 더 작다.
var x;
// 변수 선언문은 값으로 평가될 수 없으므로 표현식이 아니다.

x = 1 + 2
// 1, 2, 1 + 2, x = 1 + 2 모두 표현식이다.
// 표현식이면서 완전한 문이다.
  • 표현식인 문과 표현식이 아닌 문을 구별하는 가장 간단한 방법은 변수에 할당해 보는 것.
var foo = var x // Error

var foo = x = 10
console.log(foo) // 10



완료값

  • 크롬 개발자 도구에서 표현식이 아닌 문을 실행하면 언제나 undefined를 출력하는데, 이를 완료값이라고 한다.
  • 완료값은 표현식의 평가 결과가 아니므로, 다른 값과 같이 변수에 할당할 수도 없고, 참조할 수 도 없다.
  • 크롬 개발자도구에서 표현식인 문은 실행하면 언ㅇ제나 평가된 값을 반환한다.