• 카테고리

    질문 & 답변
  • 세부 분야

    게임 프로그래밍

  • 해결 여부

    미해결

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

21.12.31 18:32 작성 조회수 83

0

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

int  x = 0;

double y{x}; 

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

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

 

 

답변 1

답변을 작성해보세요.

0

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

심재욱님의 프로필

심재욱

질문자

2022.01.01

감사합니다!!

가또님의 프로필

가또

2022.01.01

저..추가로 질문이 있습니다 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은 표현하고있습니다!

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