inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

6.5 사실과 거짓

표현식의 자료형

해결된 질문

248

이재완

작성한 질문수 28

1

안녕하세요. 5-11 형변환을 공부하다가 궁금한 점이 생겨 질문드립니다.

13행에서 변수 i에, 강제로 float로 변환된 표현식 'f + 2 * c;'의 값이 저장되는 것으로 이해했습니다.

cpu는 다른 자료형들을 연산할 수 없기 때문에 컴파일러가 표현식의 자료형을 동일하게 변환시키는 것은 이해됩니다.

그런데 변할 때 피연산자들 중 상대적으로 더 큰 자료형을 갖는 피연산자에 맞춰 변환되는 것인가요?

즉 13행의 경우는 실수 자료형을 갖는 변수 f가 정수인 '2 * c' 보다 더 큰 자료형이기 때문에 두 피연산자를 더한 값의 자료형이 float가 되는 것인가요?

늘 좋은 답변 감사합니다.

c

답변 1

2

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

네, 말씀하신 내용이 맞습니다.
다만, 일반적으로 intfloat 자료형의 크기는 4 바이트로 같습니다.

C 언어에서 피연산자들의 자료형이 다른 경우, 컴파일러는 표현식의 자료형을 변환시킵니다.
이때 변환 규칙 중 하나는 "두 개의 피연산자 중 더 높은 정밀도를 표현할 수 있는 자료형에 맞춰 변환" 하는 것입니다.

따라서 f + 2 * c;표현식에서, 2 * cint 자료형이고 ffloat 자료형인데, floatint 보다 상대적으로 더 높은 정밀도를 표현할 수 있으므로, 2 * cfloat 으로 형변환이 일어납니다.
따라서, 두 피연산자를 더한 값의 자료형은 float 이 됩니다.
그 후에 i = f + 2 * c; 코드 라인에서는 float 자료형이었던 결과값이 int형 변수 i에 저장되기 위해 다시 int 형으로 변환됩니다.
말씀하신 표현식에서는 아니지만, 만약 계산 결과 소수점 이하의 값이 있다면, 그 값은 버려지게 됩니다.

Export template 안됨

1

31

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

57

3

main 함수에서 왜 int만 선언이 되는걸까요

1

57

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

55

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

49

1

프로토타입과 함수간의 인자 불일치

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

138

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

61

2

getchar(), putchar()

1

94

3

강의자리ㅛ

1

80

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

114

2

소스파일안에 여러 파일

1

76

2

F5와 F7의 차이

1

79

2

c = TWO * (a+b); 에서 a와 b는?

1

60

2

; 세미콜론을 붙이는 기준에 문의

1

70

1

Step over 기능 문의

1

53

2

2.6 강의 따옴표 출력 규칙 문의

1

76

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

61

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

65

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

54

2