인프런 커뮤니티 질문&답변

심재욱님의 프로필 이미지
심재욱

작성한 질문수

[C++과 언리얼로 만드는 MMORPG 게임 개발 시리즈] Part1: C++ 프로그래밍 입문

중괄호 초기화에 대해서 질문드립니다.

작성

·

124

0

축소변환 방지의 예시로 들어주신 것이 이해가 안돼서 질문드립니다.

int  x = 0;

double y{x}; 

가 통과가 안된다는게 이해가 안됩니다. int -> double 변환인데 이것은  축소 변환이 아니라

확대 변환이여서 데이터 손실이 없지 않나요?? 왜 통과가 안되는지 궁금합니다.

 

 

답변 1

0

Rookiss님의 프로필 이미지
Rookiss
지식공유자

축소 변환은 데이터 [범위가 축소되는] 것이라기 보다는
[변환 중에 데이터 손실이 있는] 것입니다.
int의 모든 숫자를 정확하게 double이 표현하지 못하고
특히 숫자가 커질 수록 미세한 오차가 날 수 있습니다.
애당초 float, double은 근사치에 불과합니다.

심재욱님의 프로필 이미지
심재욱
질문자

감사합니다!!

저..추가로 질문이 있습니다 double의 경우 가수부가 52bit로 int의 32bit보다 크기 때문에 정확도 면에서 모든 int가 정확하게 표현 될 수 있습니다.

float의 경우 가수부가 23bit이기 때문에 int변환시 손실이 있을 수 있습니다만

double의 경우는 그런 경우는 없을거라 생각하는데요 혹시 조금 더 자세히 알려주실 수 있나요..?

실제로 

unsigned int i = -1;

double d = i;

 

cout.precision(10);

 

cout << i << endl;

cout << d << endl;

로 테스트 해봤을 경우에 int형이 가질수 있는 최대 자리수인 10자리수에서 모든 값을 double은 표현하고있습니다!

Rookiss님의 프로필 이미지
Rookiss
지식공유자

음 생각해보니 그렇네요.
예제를 int64 -> double이나 int -> float로 생각해주시기 바랍니다

심재욱님의 프로필 이미지
심재욱

작성한 질문수

질문하기