Develop
2003.04.23 00:07
[C] C언어의 조건 연산자(Conditional Operator)
Views 14279 Comment 0
C 언어의 조건 연산자(conditional operator)에는 다음과 같은 3항(ternary)연산자가 있다.
수식1 ? 수식2 ? : 수식3
이 조건 연산자는 수식1이 먼저 평가되어 참(0 이외의 값)이면 수식2가 평가되고, 거짓(0의 값)이면 수식3이 평가된다. 이 형식은 6장에서 언급할 if 문의 형태로 표현할 수 있다. 예를 들어,
min = (y < z) ? y : z;
는
if (y < z)
min = y;
else
min = z;
로 표현할수 있으며, 그 의미는 y가 z보다 작으면 min에 y값을 배정하고, 그렇지 않으면 min 에 z값을 배정한다.
한편, '수식1 ? 수식2 : 수식3' 의 형(type)은 수식2와 수식3의 형에 의해 결정된다.
따라서 수식2와 수식3이 서로 다른 형이면 일반적인 형 변환 규칙이 적용된다. 주의 할 점은 수식2 또는 수식3 두 수식 중 어느 하나가 평가되는가와 관계없이 형 변환이 일어난다는 점이다.
이러한 조건 연산자의 사용 예와 연산 우선 순위 및 결합성은 다음과 같다.
예5. 18 조건 연산자의 연산 우선 순위의 결합성
[변수 선언 및 값의 배정]
char a='a', b='b', c='c'; /* a는 10진값 97을 가짐 */
int i=1, j=2, k=3;
float x=3.337;
수식 | 우선 순위와 결합성 | 결과값 | 형 |
i==j?a-1:b+1 | (i==j)?(a-1):(b+1) | 99 | int |
k%3==0?i:x+1 | ((k%3)==0)?i:(x+1) | 1.0 | double |
k%3?i:x+1 | (k%3)?i:(x+1) | 4.337 | double |
문장 | 출력 결과 | ||
printf("n%d tree%c", k, (k==1)?'':'s'); | 3trees | ||
printf"n%d frog%c", k, (k==1)?'':'s'); | 1frog |
조건연산자는 오른쪽에서 왼쪽으로 결합성을 갖는다.
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
685 | Develop |
[c++] 헤더, 소스 파일 분리해서 작성해본 테스트 소스
![]() |
hooni | 2013.04.23 | 6715 |
684 | Develop |
[c++] 현승이가 준 P2P 프로그램 소스 ㅋㅋ
![]() |
hooni | 2013.04.23 | 12100 |
683 | Develop |
[c++] 현승이가 준 메신저 소스.. ㅋㅋ
![]() |
hooni | 2013.04.23 | 8296 |
682 | Develop | [c++][mfc] 파일 입출력 샘플 (한줄씩 읽어서 다른 파일에 쓰기) | hooni | 2013.04.23 | 15040 |
681 | Develop |
[c++]현승이가 보내준 동영상 암호화 자료.. 볼것..
![]() |
hooni | 2003.04.23 | 9754 |
680 | Develop |
[c++]현승이가 보내준 암호화 모듈 AES라인델..
![]() |
hooni | 2003.04.23 | 10742 |
679 | Develop | [c/c++] Makefile 사용하기.. ㅋㅋ | hooni | 2003.04.23 | 7389 |
678 | Develop |
[chm] C++ 문법 가이드
![]() |
hooni | 2013.04.23 | 7966 |
677 | Develop |
[chm] Programming Applications for Microsoft Windows
![]() |
hooni | 2013.04.23 | 7279 |
676 | Develop |
[chm] 비주얼 C++ 팁 모음 문서
![]() |
hooni | 2013.04.23 | 7518 |
675 | Develop |
[chm] 윈도우즈에서 디버깅 기법(Debugging Applications)
![]() |
hooni | 2013.04.23 | 7547 |
674 | Develop | [coding] Find all anagrams in a string | hooni | 2017.06.27 | 1290 |