[자바스크립트]

[JavaScript/DeepDive]08.제어문

ki7348 2021. 5. 9. 15:55
  • 제어문은 조건에 따라 코드 블록을 실행하거나 반복 실행할 때 사용한다.
  • 제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.
    • 제어문은 코드의 흐름을 이해하기 어렵게 만들어 가독성을 해치는 단점이 존재할 수 있다.

 

 

  • [8.1] 블록문
  • 블록문은 0개 이상의 문을 중괄호로 묶은 것으로, 코드 블록 또는 블록이라고 부르기도 한다.
  • 자바스크립트는 블록문을 하나의 실행 단위로 취급한다.
    • 블록문은 단독으로 사용할 수도 있으나 제어문이나 함수를 정의할 때 사용하는 것이 일반적이다.

 

  • [8.2] 조건문
  • 조건문은 주어진 조건식의 평가 결과에 따라 코드 블록의 실행을 결정한다.
    • 조건식은 불리언 값으로 평가될 수 있는 표현식이다.
  • 자바스크립트는 if ... else 문과 switch 문으로 두 가지 조건문을 제공한다.
  • if ... else 문은 주어진 조건식의 평가 결과, 즉 논리적 참 또는 거짓에 따라 실행할 코드 블록을 결정한다.
  • 조건식의 평가 결과가 true일 경우 if 문의 코드 블록이 실행되고 false일 경우 else문의 코드 블록이 실행된다.
  • 만약 if 문의 조건식이 불리언 값이 아닌 값으로 평가되면 자바스크립트 엔진에 의해 암묵적으로 불리언 값으로 강제 변환되어 실행할 코드 블록을 결정한다.
  • 대부분의 if ... else 문은 삼항 조건 연산자로 바꿔 쓸 수 있다.
  • if ( x % 2) {
      result = '홀수';
    } else {
      result = '짝수';
    }
  • var result = x % 2 ? '홀수' : '짝수' ; //다음과 같은 삼항 조건 연산자로 바꿔 쓸 수 있다.
  • 삼항 조건 연산자는 값으로 평가되는 표현식을 만든다. 
    • 삼항 조건 연산자 표현식은 값처럼 사용할 수 있기 때문에 변수에 할당할 수 있다.
      • if ... else 문은 표현식이 아닌 문이므로 값처럼 사용할 수 없기 때문에 변수에 할당할 수 없다.
  • switch 문은 주어진 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행 흐름을 옮긴다.
  • switch 문의 표현식과 일치하는 case 문이 없다면 실행 순서는 default 문으로 이동한다.
    • default 문은 선택사항으로, 사용할 수도 있고 사용하지 않을 수도 있다.
  • switch 문의 표현식은 불리언 값보다는 문자열이나 숫자 값인 경우가 많다.
    • switch 문은 논리적 참, 거짓보다는 다양한 상황에 따라 실행할 코드 블록을 결정할 때 사용한다.
  • break 키워드로 구성된 break 문은 코드 블록에서 탈출하는 역할을 한다.
    • Fall through(폴스루): break 문이 없다면 case 문의 표현식과 일치하지 않더라도 실행 흐름이 다음 case 문으로 연이어 이동한다.
      • default 문에는 break 문을 생략하는 것이 일반적이다.
        • default 문은 switch 문의 맨 마지막에 위치하므로 default 문의 실행이 종료되면 switch 문을 빠져나간다.
  • 조건이 너무 많아서 if ... else 문보다 switch 문을 사용했을 때 가독성이 더 좋다면 switch 문을 사용하는 편이 좋다.

 

 

  • [8.3] 반복문
  • 반복문은 조건식의 평가 결과가 참인 경우 코드 블록을 실행한다.
    • 그 후 조건식을 다시 평가하여 여전히 참인 경우 코드 블록을 다시 실행한다.
      • 이는 조건식이 거짓일 때까지 반복된다.
  • for 문은 조건식이 거짓으로 평가될 때까지 코드 블록을 반복 실행한다.
  • for ( 변수 선언문 또는 할당문; 조건식; 증감식) {
        조건식이 참인 경우 반복 실행될 문;
    }
  • for 문의 변수 선언문, 조건식, 증감식은 모두 옵션이므로 반드시 사용할 필요는 없다.
    • 단, 어떤 식도 선언하지 않으면 무한루프가 된다.
  • while 문은 주어진 조건식의 평가 결과가 참이면 코드 블록을 계속해서 반복 실행한다.
  • for 문은 반복 횟수가 명확할 때 주로 사용하고 while 문은 반복 횟수가 불명확할 때 주로 사용한다.
  • while 문은 조건문의 평가 결과가 거짓이 되면 코드 블록을 실행하지 않고 종료한다.
  • 만약 조건식의 평가 결과가 불리언 값이 아니면 불리언 값으로 강제 변환하여 논리적 참, 거짓을 구별한다.

 

  • do ... while 문은 코드 블록을 먼저 실행하고 조건식을 평가한다.
    • 따라서 코드 블록은 무조건 한 번 이상 실행된다.

 

 

  • [8.4] break 문
  • break 문은 레이블 문, 반복문, switch 문의 코드 블록을 탈출한다.
    • 이외에 break 문을 사용하면 SyntaxError(문법 에러)가 발생한다.
  • 레이블 문이란 식별자가 붙은 문을 말한다.
    • foo: console.log('foo');
    • 레이블 문이란 프로그램의 실행 순서를 제어하는 데 사용한다.
      • 레이블 문을 탈출하려면 break 문에 레이블 식별자를 지정한다.
  • 중첩된 for 문의 내부 for 문이 아닌 외부 for 문을 탈출하려면 레이블 문을 사용한다.
    • 레이블은 이 밖에 경우에는 일반적으로 권장되지 않는다.
  • break 문은 반복문을 더 이상 진행하지 않아도 될 때 불필요한 반복을 회피할 수 있어 유용하다.

 

 

  • [8.5] continue 문
  • continue 문은 반복문의 코드 블록 실행을 현 지점에서 중단하고 반복문의 증감식으로 실행 흐름을 이동시킨다.
  • break 문처럼 반복문을 탈출하지는 않는다.
  • if 문 내에서 실행해야 할 코드가 길다면 들여쓰기가 한 단계 더 깊어지므로 continue문을 사용하는 편이 가독성이 더 좋다.
    • for ( var i = 0; i < string.length; i++) {

          if ( string[i] !== search) continue;
      //continue 문을 사용하면 if 문 밖에 코드를 작성할 수 있다.

          count++;

      }