printf("Enter the first number: "); scanf("%d", &a);
printf("Enter the second number: "); scanf("%d", &b);
if (ch == 'A') printf("%d + %d = %d\n", a, b, a + b); else if (ch == 'S') printf("%d - %d = %d\n", a, b, a - b); else if (ch == 'D') printf("%d / %d = %d\n", a, b, a / b); else if (ch == 'M') printf("%d * %d = %d\n", a, b, a * b);
return 0;
}
출력 : a, b의 값에 따른 해당 연산 값 출력
switch(ch) { case 'A': printf("%d + %d = %d\n", a, b, a + b); break; case 'S': printf("%d - %d = %d\n", a, b, a - b); break; case 'D': printf("%d / %d = %d\n", a, b, a / b); break; case 'M': printf("%d * %d = %d\n", a, b, a * b); break; default: printf("Typing to the Char"); break; }
1번 : 'a' 문자를 할당하려고 하는 것이다. imsip = 'a';의 의미는 'a'에 해당하는 아스키코드 정수 값을 imsip에 넣으려고 하는 것과 같습니다. imsip에는 주소 외에는 다른 값이 할당 될 수 없으므로 문법적으로 옳지 않습니다. 2번 : "a"라는 문자열이 메모리의 어딘가에 저장되고 이 저장된 주소를 imsip에 대해 할당하므로 맞는 문장입니다. "a"는 뒤에 널 문자가 추가된 문자열이며 문자가 아닙니다. 3번 : 'a'문자를 imsi에 할당합니다. 아스키 정수 값이 imsi에 할당되므로 문법적으로 하자가 없습니다. 4번 : "a"는 문자열이며 문자열은 주소 값을 리턴하므로 "a"가 저장된 곳의 주소가 imsi에 할당됩니다. 물론 메모리 접근 오류이므로 에러가 나타나게 되겠습니다.
[설명] 1. temp Temp는 포인터 변수들의 모임인 포인터 배열의 모 배열입니다. 대상체는 temp 배열 전체이므로 12가 출력됩니다. 2. &temp temp가 저장된 곳의 주소를 출력하라는 뜻으로 사용했지만 temp는 배열명으로써 메모리 할당을 받지 않기 때문에 temp와 같은 값을 출력하게 되지요. 의미상으로는 맞지 않지만 ANSI에서 새로 추가하여 에러는 발생하지 않습니다... 또한 주소 값에 대한 sizeof()이므로 당연히 4가 출력됩니다. 3. *temp temp가 가리키는 것은 temp[0]입니다. temp는 temp[0], temp[1], temp[2] 전체를 대상으로 하기 때문에 12가 출력되었지만 *temp가 가리키는 대상체는 temp[0]이며 이것이 할당된 메모리 영역은 4바이트이므로 4가 출력됩니다.
Tip) temp 자체에 대한 대상체를 * 연산자를 이용하여 출력하려면 다음과 같이 하면 되겠습니다.
물론 2차원 배열에 대한 주소 값을 받은 상태라면 이것은 행 전체에 대한 크기를 출력해 줄 것입니다.
printf("%d\n", sizeof(*&temp));
4. temp[0] temp[0]은 포인터 변수이다. temp[0]을 위해서 할당된 메모리 영역은 4바이트이므로 4가 출력됩니다.
5. &temp[0] temp[0]에 &연산자를 사용하여 메모리를 출력하고 있습니다. 이 메모리에 대한 메모리 할당은 당연히 4바이트이므로 4가 출력되겠습니다.