작성
·
124
0
축소변환 방지의 예시로 들어주신 것이 이해가 안돼서 질문드립니다.
int x = 0;
double y{x};
가 통과가 안된다는게 이해가 안됩니다. int -> double 변환인데 이것은 축소 변환이 아니라
확대 변환이여서 데이터 손실이 없지 않나요?? 왜 통과가 안되는지 궁금합니다.
답변 1
0
축소 변환은 데이터 [범위가 축소되는] 것이라기 보다는
[변환 중에 데이터 손실이 있는] 것입니다.
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은 표현하고있습니다!
감사합니다!!