inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2.5 부동소수점수 floating point numbers

2.5 literal이 float로 간주되는 경우

256

나그네

작성한 질문수 37

1

12분 30초 정도에 선생님께서

int main() {

using namespace std;

float f(3.141592f);

double d;

long double ld;

return 0; } 에서

여기서 float면 3.141592뒤에 꼭 f를 붙여야 하는데 f를 안 붙이면 안의 literal은 double인데 C언어 또는 C++에서는 double을 float로 강제로 바꾼다 라고 하셨습니다.

여기서 좀 헷갈립니다...

저는 지금까지 float면 f를 확실하게 붙여야 하고, 붙이지 않으면 double로 간주된다고 알고 있었습니다.

  1. 그런데 선생님 말씀대로라면, 앞의 type를 float로 적은 상황에서, 뒤의 수는 f를 붙이지 않아도 C++에서 자동으로 float로 바꾼다고 하셨으니 f가 있든 없든 float로 컴파일되는 게 아닌가요?ㅠ

 

  1. 뒤의 literal이 double이 되려면, 앞의 type을 double d(3.141592) 이런 식으로 적지 않는 이상 방법이 없다는 걸로 이해하면 될까요?ㅠ

 

c++

답변 1

1

Soobak

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

변수의 자료형을 놓치고 계신 것 같습니다.

float f (3.141592); 에서 변수 f 의 자료형이 float 이기 때문에 컴파일러가 double 로 표현된 리터럴 3.141592float 으로 형변환해주는 것입니다. 👍

1

나그네

그럼 float f(3.141592f)과 float f(3.141592) 의 차이는 f가 있고 없고의 차이인데, 컴파일러가 f가 없어도 자동으로 float로 바꾸는 것이라면, f를 붙이는 의미가 없지 않나요?

1

Soobak

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

일단 코드의 가독성을 향상시키고, 데이터 손실의 가능성 및 컴파일러 경고를 방지하기 위해서 f 를 붙이는 것이 의미가 있다고 생각하시는 것이 적절한 것 같습니다.

f 를 붙이면, 해당 숫자를 float 으로 처리하려고 함을 명확히 보여주는 표시입니다. 따라서, 코드를 읽는 사람에게 의도를 명확히 전달할 수 있습니다.

또한, double 은 일반적으로 float 보다 더 넓은 정밀도의 숫자 표현을 보장하므로, 특정 숫자는 double 에서 float 으로 형 변환시 데이터 손상이 일어날 수도 있습니다. 따라서, 컴파일러의 경고 수준 설정에 따라서 명시적으로 f 를 사용하지 않으면 경고 메세지가 발생할 수도 있습니다.

강의자료는 어디서 받을 수 있죠?

1

36

2

교재 있나요?

1

142

2

11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)

1

95

3

using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다

1

106

2

cstr직접구현

0

119

3

BubbleSort

1

79

2

숙제 마지막 부분

1

80

2

강의와 똑같이 진행했는데 링킹 에러가 발생합니다.

1

97

2

수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??

1

165

2

공변반환형 관련 문의 드립니다.

1

92

2

170강 유니크 포인터에대해 질문있습니다

1

82

1

섹션 5 퀴즈의 답이 이상합니다

1

86

2

이중포인터와 배열이 이해가 안됩니다.

1

161

2

5분 17~5분 34초 객체 잘림 질문

1

80

1

Resource.h 코드 알려주세요

1

74

1

char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다

1

96

2

화면좌측 숫자 보이기

1

116

1

화면 좌측 숫자 보이기

0

68

1

처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??

1

139

3

46강 string 버퍼 질문입니다

1

82

2

프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.

1

126

2

[] 범위 검사시 assert 사용 관련 질문

1

92

2

Lecture 클래스 멤버변수 명명 관련

0

94

2

프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요

0

76

1