현인
8장 제어문 본문
8장 제어문
제어문은 조건에 따라 코드 블록을 실행하거나 반복 실행 할 때 사용한다. 제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.
블록문
블록문은 0개 이상의 문을 중괄호로 묶은 것으로, 코드 블록 또는 블록이라고 부르기도 한다. 자바스크립트는 블록문을 하나의 실행 단위로 취급한다. 블록문은 단독으로 사용할 수도 있으나 일반적으로는 제어문이나 함수를 정의할 때 사용한다.
문의 끝에는 세미콜론을 붙이는 것이 일반적이다. 다만, 블록문은 언제나 문의 종료를 의미하는 자체 종결성을 갖기 때문에 블록문의 끝에는 세미콜론을 붙이지 않는다.
// 블록문
{
var foo = 1;
}
// 제어문
var x = 1;
if (x < 10) {
x++;
}
조건문
조건문은 주어진 조건식의 평가 결과에 따라 코드 블록의 실행을 결정한다. 조건식의 평가 결과가 true일 경우 if 문의 코드 블록이 실행되고 false 일 경우 else 문의 코드 블록이 실행된다.
if ... else 문
if ... else 문은 주어진 조건식의 평가 결과 즉, 논리적 참 또는 거짓에 따라 실행할 코드 블록을 결정한다.
조건식의 평가 결과가 true 일 때, if 문의 코드 블록을 실행하고
조건식의 평가 결과가 false 일 때, else 문의 코드 블록을 실행한다.
만약 조건식을 추가하고 싶다면, else if 문을 사용하여 추가적인 조건을 부여하고 실행할 코드 블록을 정의할 수 있다. if 문과 else 문은 2번 이상 사용할 수 없지만 else if 문은 여러 번 사용가능하다.
만약 코드 블록 내의 문이 하나뿐이라면 중괄호를 생략할 수 있다.
대부분의 if ... else 문은 삼항 연산자로 바꿔 쓸 수 있다.
var x = 3;
// if...else문
if (x % 2 == 0) {
console.log("짝수");
}
else {
console.log("홀수");
}
// 삼항연산자
console.log( x % 2 == 0 ? "짝수" : "홀수");
삼항 조건 연산자 표현식은 값처럼 사용할 수 있지만 if...else 문은 표현식이 아닌 문이기 때문에 값처럼 사용할 수 없다.
조건에 따라 단순히 값을 결정하여 변수에 할당하는 if...else 문보다 삼항 조건 연산자를 사용하는 편이 가독성이 좋다. 하지만 조건에 따라 실행해야 할 내용이 복잡하여 여러 줄의 문이 필요하다면 if ... else 문을 사용하는 편이 가독성이 좋다.
switch 문
switch 문은 주어진 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행 흐름을 옮긴다. case 문은 상황을 의미하는 표현식을 지정하고 콜론으로 마친다.
switch 문의 표현식과 일치하는 case 문이 없다면 default 문으로 이동한다. default 문은 선택사항이다.
if ... else 문의 조건식은 불리언 값으로 평가되어야 하지만 switch 문의 표현식은 불리언 값보다는 문자열이나 숫자 값인 경우가 많다. 다시 말해, 논리적 참, 거짓을 분리하는 경우보다 다양한 상황에 따라 실행할 코드 블록을 결정할 때 사용한다.
예를 들면, 현재 몇월인지 입력 받고 해당 월의 영어 명칭을 출력하는 상황에 적합하다.
switch 문을 사용할 때 break 문을 활용하여 알맞은 case에서 switch 문을 탈출해야 한다. 만약 break 문을 사용하지 않는다면 switch 문을 탈출하지 않고 아래 case 도 실행된다. 이를 폴스루라 한다.
break 문을 생략한 폴스루를 의도적으로 사용하는 경우도 있다.
default 문은 마지막에 위치하므로 break 문이 필요 없다.
switch 문은 case, break, default 등 다양한 키워드를 사용해야 하고 폴스루가 발생하는 등 문법도 복잡하다. 따라서 switch 문을 지원하지 않는 언어도 있다.
만약 if...else 문으로 해결할 수 있다면 if...else 문을 사용하는 편이 좋다. 하지만 조건이 너무 많아서 switch 문을 사용했을 때 가독성이 더 좋다면 switch 문을 사용해도 좋다.
반복문
반복문은 조건식의 평가 결과가 참인 경우 코드 블록을 실행한다. 그 후 조건식을 다시 평가하여 여전히 참인 경우 코드 블록을 다시 실행한다. 이는 조건식이 거짓일 때 까지 반복된다.
자바스크립트는 세 가지 반복문을 제공한다
- for
- while
- do...while
for 문
for 문의 구조는 다음과 같다
for (변수 선언문 또는 할당문; 조건식; 증감식){
조건식이 참인 경우 반복 실행될 문;
}
실행 흐름은 다음과 같다.
- 변수 선언문 또는 할당문이 실행된다
- 조건식을 판별한다
- 참인 경우 코드블록을 실행하고, 거짓인 경우 반복문을 탈출한다.
- 증감식을 실행한다.
- 2번 과정으로 돌아간다
for 문의 변수 선언문, 조건식, 증감식은 모두 옵션이므로 반드시 사용할 필요는 없다. 단, 어떤 식도 선언하지 않으면 무한 루프가 된다.
for 문 내에 for 문을 중첩해 사용할 수 있다
while 문
while 문의 구조는 다음과 같다
while (조건식) {
조건식이 참일 때 실행할 코드;
}
실행 흐름은 다음과 같다.
- 조건식을 판별한다.
- 조건식이 참인 경우 코드블록을 실행하고, 거짓인 경우 반복문을 탈출한다.
- 1번으로 돌아간다.
for 문은 반복 횟수가 명확할 때 주로 사용하고, while 문은 반복 횟수가 불명확할 때 주로 사용한다.
do...whlie 문
do...while 문의 구조는 다음과 같다.
do {
실행할 내용;
} while (조건식);
실행 흐름은 다음과 같다.
- do 코드 블록을 먼저 실행한다.
- 조건식을 판별한다.
- 조건식이 참인 경우 do 코드 블록을 실행하고, 거짓인 경우 반복문을 탈출한다.
- 2번으로 돌아간다.
while 문과의 차이점은 조건식 판별 전에 먼저 코드 블록을 실행 한다는 점이다. 따라서 코드 블록이 무조건 한 번 이상 실행된다.
break 문
break 문은 코드 블록을 탈출하는데 사용한다. 좀 더 정확히 표현하면 레이블 문, 반복문 또는 switch 문의 코드 블록을 탈출한다. 이 외에 경우에 break 문을 사용하는 경우 SyntaxError(문법 에러)가 발생한다.
레이블 문이란 식별자가 붙은 문을 말한다. switch 문에서 case 문과 default 문도 레이블문의 일종이다. 레이블 문을 탈출하려면 break 문에 레이블 식별자를 사용한다. 중첩된 for 문에서 외부 for 문을 탈출할 때도 레이블문을 사용한다. 레이블 문은 중첩된 for 문을 탈출할 때 유용하지만 그 밖의 경우에서는 일반적으로 권장하지 않는다.
break 문을 적절히 사용하면 불필요한 반복을 피할 수 있다.
continue 문
반복문의 코드 블록 실행을 현 지점에서 중단하고 반복문의 증감식으로 실행 흐름을 이동시킨다. break 문처럼 반복문을 탈출하진 않는다. 따라서 증감식이 있는 for 문에서 주로 사용된다.
for 문 안에 if 문에서 실행할 내용이 여러 줄이라면, 해당 경우를 제외한 즉, if 문이 거짓인 경우를 continue로 처리하여 블록을 한 단계 들여쓰지 않도록 할 수 있다.
// continue 문을 사용하지 않으면 if 문 내에 코드를 작성해야 한다.
for (var i = 0; i < string.length; i++){
if (string[i] === search){
// 실행할 코드
// 실행할 코드
// 실행할 코드
// 실행할 코드
}
}
// continue 문을 사용하면 if 문 밖에 코드를 작성할 수 있다.
for (var i = 0; i < string.length; i++){
// 조건식이 거짓인 경우 continue를 사용하여 다음 반복으로 넘기기
if (string[i] !== search) continue;
// 실행할 코드
// 실행할 코드
// 실행할 코드
// 실행할 코드
}
마치며
코드의 실행 순서가 변경된다는 것은 단순히 위에서 아래로 순차적으로 진행하는 직관적인 코드의 흐름을 혼란스럽게 만든다. 따라서 제어문은 코드의 흐름을 이해하기 어렵게 만들어 가독성을 해치는 단점이 있다. 자바스크립트는 고차 함수를 사용한 프로그래밍 기법으로 제어문의 사용을 억제하여 복잡성을 해결하려고 노력한다. 이후 고차 함수에서 해당 내용을 더 공부해볼 예정이다.
제어문은 기본적인 내용이고 많은 프로그래밍 언어에서 통용되는 개념이다. 여러 언어를 공부해보았기에 이해하는데 어렵지 않았다. 다만 레이블문 같은 내용은 새로운 내용이라 잘 이해해 두면 좋을 것 같다.
참고 문헌
- 이웅모. 『모던 자바스크립트 Deep Dive』. 위키북스, 2020.
'기술 학습 > JavaScript' 카테고리의 다른 글
16장 프로퍼티 어트리뷰트 (0) | 2023.07.20 |
---|---|
15장 let, const 키워드와 블록 레벨 스코프 (0) | 2023.07.20 |
6장 데이터 타입 (0) | 2023.06.12 |
5장 표현식과 문 (0) | 2023.05.30 |
4장 변수 (0) | 2023.05.27 |