08 제어문

연우·2024년 11월 6일
0
  • 제어문은 조건에 따라 코드 블록을 실행하거나 반복 실행할 때 사용한다.
  • 제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.
  • 그러나 제어문은 코드의 흐름을 이해하기 어렵게 만들어 가독성을 해치는 단점이 있다.
  • forEach, map, filter, reduce 같은 고차 함수를 사용해 제어문 사용을 억제해 복잡성을 해결하려고 노력한다.

8.1 블록문

  • 블록문은 0개 이상의 문을 중괄호로 묶은 것으로, 코드 블록 또는 블록이라고 부르기도 한다.
  • 하나의 실행 단위로 취급
  • 단독으로도 사용 가능하나 일반적은로 제어문이나 함수를 정의할 때 사용
{
	var foo = 10;
}

8.2 조건문

  • 조건문은 주어진 조건식의 평가 결과에 따라 코드 블록의 실행을 결정
  • 저건식은 불리언 값으로 평가될 수 있는 표현식
  • 자바스크립트는 if...else 문과 switch 문으로 두가지 조건문 제공

8.2.1 if...else 문

  • if...else 문은 주어진 조건식의 평과 결과에 따라 실행할 코드 블록을 결정
if(조건식){
	// 조건식이 참이면 이 코드 블록 실행
}else{
	// 조건식이 거짓이면 이 코드 블록 실행
}
  • 만약 if의 조건식이 불리언 값이 아닌 값이면 암묵적으로 불리언 값으로 강제 변환되어 실행할 코드 블록 결정
  • 만약 코드 블록 내의 문이 하나뿐이라면 중괄호를 생략할 수 있다.
var num = 2;
var kind;
if(num>0) kind = '양수';
else if(num) kind = '음수';
else kind = '영';

console.log(kind); // 양수

// 삼항 조건 연산자로 바꿔 쓸 수 있다.
var kind = num ? (num > 0 ? "양수" : "음수") : "영"

8.2.2 switch 문

  • switch 문은 주어진 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행흐름을 옮긴다.
  • case 문은 상황을 의미하는 표현식을 지정하고 콜른으로 마친다
  • 일치하는 case 문이 없다면 실행 순서는 default 문으로 이동
switch(표현식){
	case 표현식1:
    	switch 문의 표현식과 표현식1이 일치하면 실행될 문;
    	break;
    case 표현식2:
    	switch 문의 표현식과 표현식2이 일치하면 실행될 문;
    	break;
    default:
    	switch 문의 표현식과 일치하는 case 문이 없을 때 실행될 문;   
}

-switch 문은 다양한 상황에 따라 실행할 코드 블록을 결정할 때 사용한다.

var month = 11;
var monthName;

switch(month){
	case 1: monthName = 'January';
    case 2: monthName = 'February';
    case 3: monthName = 'March';
    case 4: monthName = 'April';
    case 5: monthName = 'May';
    case 6: monthName = 'June';
    case 7: monthName = 'July';
    case 8: monthName = 'August';
    case 9: monthName = 'September';
    case 10: monthName = 'October';
    case 11: monthName = 'November';
    case 12: monthName = 'Desember';
    default: monthName = 'Invalid month';
}

console.log(monthName); // Invalid month
  • 위 예제를 실행해 보면 'November'가 아닌 'Invalid month'가 출력된다.
  • 일치하는 값이 할당된 후 switch 문을 탈출하지 못하고 연이어 다음 case 문이 재할당 되는데 그것을 폴스루 라고 한다
  • case 문에 마지막에 break 문을 사용하지 않았기 때문이다.
var month = 11;
var monthName;

switch(month){
	case 1: monthName = 'January';
    	break;
    case 2: monthName = 'February';
    	break;
    case 3: monthName = 'March';
    	break;
    case 4: monthName = 'April';
    	break;
    case 5: monthName = 'May';
    	break;
    case 6: monthName = 'June';
    	break;
    case 7: monthName = 'July';
    	break;
    case 8: monthName = 'August';
    	break;
    case 9: monthName = 'September';
    	break;
    case 10: monthName = 'October';
    	break;
    case 11: monthName = 'November';
    	break;
    case 12: monthName = 'Desember';
    	break;
    default: monthName = 'Invalid month';
}

console.log(monthName); // November
  • default 문은 맨 마지막에 위치하므르 break 문을 생략한다.

8.3 반복문

  • 반복문은 조건식의 평가 결과가 참인 경우 코드 블록을 실행 그 후 조건식을 다시 평가하여 여전히 참인 경우 코드 블록을 다시 실행
  • 거짓일 때 까지 반복된다.
  • 자바스크립트는 세가지 반복문인 for 문, while 문, do...while 문을 제공

8.3.1 for 문

  • for 문은 조건식이 거짓으로 평가될 때 까지 코드 블록을 반복 실행한다.
for(변수 선언문 또는 할당문; 조건식; 증감식){
	조건식이 참인 경우 반복 실행될 문
}

for(var i = 0; i < 2; i++){
	console.log(i)
}
// 0
// 1
  • for 문의 어떤 식도 선언하지 않으면 무한 루프가 된다
// 무한 루프
for(;;){...}
  • for 문 내에 for 문을 중첩해 사용할 수 있다.
  • 중첩 for 문이라 한다.
for(var i = 0; i <= 6; i++){
	for(var j= 1; j <=6; j++){
    	if(i + j ===6) console.log(`[${i}, ${j}]`);
    }
}
// [1, 5]
// [2, 4]
// [3, 3]
// [4, 2]
// [5, 1]

8.3.2 while 문

  • while 문은 주어진 조건식의 평가가 참이면 코드 블록을 계속해서 반복 실행
  • while 문은 반복 횟수가 불명확할 때 주로 사용
  • while 문은 평가 결과가 거짓이 되면 실행하지 않고 종료
var count = 0;

while(count < 3){
	console.log(count); // 0 1 2
    count++;
}
  • 조건식의 결과가 언제나 참이면 무한루프가 된다.
  • 무한루프에서 탈출하기 위해서는 if문으로 탈출 조건을 만들고 break 문으로 탈출
var count = 0;

while(true){
	console.log(count); // 0 1 2
    count++;
  
  	if(count ===3) break;
} // 0 1 2

8.3.3 do...while 문

  • do...while 문은 코드 블록읗 먼저 실행하고 조건식을 평가
  • 따라서 코드 블록은 무조건 한 번 이상 실행
var count = 0;

do{
	console.log(count) // 0 1 2
    count++;
}while (coutn < 3);

8.4 break 문

  • 레이블 문, 반복문 또는 switch 문의 코드 블록을 탈출 한다.
  • 외에 사용하면 문법에러가 발생한다.
  • 레이블 문이란 식별자가 붙은 문을 말한다
// foo 라는 식별자가 붙은 레이블 블럭문
foo: {
	console.log(1);
    break foo;
    console.log(2);
}
console.log('Done!')
  • 레이블 문은 프로그램의 실행 순서를 제어하는 데사용
  • 중첩된 for 문에서 외부 for 문을 탈출하려면 레이블 문을 사용한다.
  • 레이블 문은 중첩된 for 문 외부로 탈출할 때 유용하지만 그 이외는 가독성과 오류 발생의 이유로 권장하지 않는다.

8.5 continue 문

  • continue 문은 반복문의 코드 블록 실행을 현 지점에서 중단하고 반복문의 증감식으로 실행흐름을 이동시킨다.
  • break 문처럼 반복문을 탈출하지 않는다
var string = 'Hello world.'
var search = 'l'
var coutn = 0;

// 문자열은 유사 배열이므로 for 문으로 순회할 수 있다.
for(var i = 0; i < string.length; i++){
	//'l'이 아니면 현 지점에서 실행을 중단하고 반복문의 증감식으로 이동
  	if(string[i] !== search) continue;
  	count++; // continue 문이 실행되면 이 문은 실행되지 않는다
}

console.log(count) //3

0개의 댓글