우리가 어떤 조건문을 기술할 때 일반적으로 if 구문을 쓰게 됩니다.
그런데, 여러 개의 동일한 표현식의 조건문을 기술할 때 if 구문을 사용하는 것보다 switch 구문을 사용하게 되면 코드 해독성이 좋습니다.
예를 들어, 다음과 같이 if 구문만으로 기술된 조건문을 볼까요.
<?
$var = 10;
if($var == 5) {
echo("value : 5");
} else if($var == 10) {
echo("value : 10");
} else if($var == 15) {
echo("value : 15");
} else {
echo("unknown value ...");
}
?>
위 코드는 $var 변수값을 각각의 조건식에서 비교해서 해당되는 문장을 실행하는 코드이죠.
그런데, switch 구문을 사용하면 다음과 같이 위 코드를 좀 더 보기 쉽게 바꿀수 있죠.
<?
$var = 10;
switch ($var) {
case (5) :
echo("value : 5");
break;
case (10) :
echo("value : 10");
break;
case (15) :
echo("value : 15");
break;
default :
echo("unknown value ...");
}
?>
if 구문으로 기술된 코드보다는 switch 구문으로 기술된 코드가 코드를 이해하는데 좀 더 수월하죠.
그럼, 위 switch 구문이 사용된 예제를 잠깐 살펴볼까요.
위 코드에서 break 문은 반복 제어문에 사용되는 break 구문과 비슷한 역할을 하는 것으로 switch 구문이 사용된 블럭을 빠져나가게 합니다.
그래서, 만일 위 코드의 "case (10)" 의 작은 블럭문에 포함된 break 문을 쓰지 않으면 다음 break 문이 나올 때까지 혹은 switch 블럭이 끝날 때까지 그 중간에 포함된 코드를 모두 실행하게 되죠.
그리고, 위 switch 구문의 마지막에 보이는 default 문은 if 구문의 else 문과 비슷한 역할을 하는 것으로 switch 구문에 포함된 조건식들에 모두 만족하지 않을 때 default 문에 포함된 코드가 실행되게 하죠.
그럼, 다음 예제는 어떤 프로그램일까요?
<?
$var = 3;
switch ($var) {
case (1) :
case (2) :
case (3) :
echo("변수값이 4보다 작습니다.");
break;
default :
echo("변수값이 4보다 크거나 같습니다");
}
?>
네, $var 변수값이 1 에서 3 사이이면 "4보다 작다"는 메시지를 출력하고 그 조건에 만족하지 않으면 "4보다 크거나 같다"는 메시지를 출력하는 프로그램이죠.
따라서, 위 코드를 실행하면 변수값이 4보다 작습니다. 라고 나오겠죠.
게시글 목록
| 번호 | 제목 |
|---|---|
| 26573 | |
| 7309 | |
| 19780 | |
| 7306 | |
| 28025 | |
| 28020 | |
| 28010 | |
| 7304 | |
| 7302 | |
| 7295 | |
| 7292 | |
| 7287 | |
| 19779 | |
| 7284 | |
| 7279 | |
| 7278 | |
| 28009 | |
| 31753 |
그누보드5
그누보드5 강좌 - 갤러리스킨 만들기
|
| 31752 | |
| 7274 | |
| 31751 | |
| 31750 |
그누보드5
그누보드5 강좌 - 네비게이션적용하기
|
| 31749 |
그누보드5
그누보드5 강좌 - 네비게이션적용하기
|
| 31748 |
그누보드5
그누보드5 강좌 - 스킨적용하기
|
| 30979 | |
| 31747 |
그누보드5
그누보드5 강좌 - 홈페이지만들기 실전#2
|
| 28004 | |
| 31745 |
그누보드5
그누보드5 강좌 - 홈페이지만들기 실전
1
|
| 7267 | |
| 7261 | |
| 31742 |
그누보드5
그누보드강좌 샘플
2
|
| 7256 | |
| 19776 |
node.js
mysql 연결 방법 2가지
2
|
| 24650 | |
| 7252 | |
| 7248 | |
| 28002 | |
| 19772 |
JavaScript
한글로 된 숫자를 아라비아 숫자로 변환
3
|
| 7245 | |
| 19770 | |
| 19769 | |
| 30975 | |
| 7243 | |
| 7236 | |
| 28001 | |
| 27994 | |
| 7233 | |
| 7232 | |
| 19768 |
jQuery
제이쿼리로 이미지 회전 시키기
|
| 19765 |
jQuery
구형 익스에서 HTML5 적용시키기
2
|
| 19763 |
jQuery
특정 레이어 높이 100% 잡는 법
1
|
| 30974 | |
| 7224 | |
| 19761 |
jQuery
모바일 해상도에 맞게 이미지 출력
1
|
| 24645 | |
| 19760 | |
| 19758 |
jQuery
제이쿼리를 이용하여 동영상 재생
1
|
| 19757 | |
| 19754 | |
| 19753 |
jQuery
브라우저 상단에 고정 시키는 제이쿼리 소스
|
| 19752 | |
| 19751 |
PHP
php 에러 출력하기
|
| 7223 | |
| 7216 | |
| 7213 | |
| 31741 |
AngularJS
AngularJS 강좌 9. HTML DOM
|
| 19750 |
jQuery
1원팁] css에 hover효과를 제이쿼리로
|
| 19749 |
JavaScript
1원팁]알고 있음 좋은 자바스크립트 함수
|
| 19748 |
jQuery
제이쿼리 기본 효과 메소드
|
| 31740 |
AngularJS
AngularJS 강좌 8. SQL
|
| 31739 |
AngularJS
AngularJS 강좌 7. Tables
|
| 31738 |
AngularJS
AngularJS 강좌 6. XMLHttpRequest
|
| 7208 | |
| 31737 |
AngularJS
AngularJS 강좌 5. Filters
|
| 30967 | |
| 31736 |
AngularJS
AngularJS 강좌 4. Controllers
|
| 7205 | |
| 30965 |
HTML
팁]모바일에서 전화 걸기
1
|
| 30963 | |
| 19747 | |
| 19746 |
기타
viewport 사용
|
| 19745 | |
| 19744 | |
| 19742 | |
| 7193 | |
| 7191 | |
| 31735 |
AngularJS
AngularJS 강좌 3. Directives
|
| 19741 |
jQuery
무한 스크롤 (이미지 갤러리용)
|
| 19740 |
PHP
[알고리즘] 하노이의 탑
|
| 19739 | |
| 7188 | |
| 27986 | |
| 31734 |
AngularJS
AngularJS 강좌 2. Expressions
|
| 31733 |
AngularJS
AngularJS 강좌 1. Introduction
|
| 31732 |
AngularJS
AngularJS 강좌 0. Home
|
| 7186 | |
| 19738 | |
| 19736 |
JavaScript
[알고리즘] 스택(stack)을 이용한 간단 계산기
1
|
| 7180 | |
| 7165 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기