inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

중괄호 초기화 { }

int->float는 확대변환 인데 왜 축소변환 오류가 나는걸까요?

해결된 질문

1183

baljang

작성한 질문수 35

2

int x =0; 

double y2{x}; 

이렇게 하면 int가 float으로 바뀌는 거니

데이터가 손실되지 않고

확대변환 되는거 아닌가요? 

왜 축소변환이 필요하다는 error가 뜨는 걸까요? 

C++

답변 1

1

Rookiss

축소 변환은 데이터 변수의 크기를 얘기하는게 아닙니다.

축소 변환 은 가능한 값의 일부를 저장하지 못할 수도 있는 데이터 형식으로 값을 변경합니다. 예를 들어 소수 값은 정수 계열 형식으로 변환될 때 반올림되고 로 변환되는 숫자 형식은 또는 로 Boolean True False 줄어듭니다.

https://docs.microsoft.com/ko-kr/dotnet/visual-basic/programming-guide/language-features/data-types/widening-and-narrowing-conversions

int -> float 변환은 완벽하게 이루어지지도 않고
애당초 float는 일종의 근사치를 개념하는 것입니다. (지수부+로그부 합해서)
상식적으로 int의 범위는 –2,147,483,648 ~ 2,147,483,647
반면 float의 범위는 -3.4×1038 ~ 3.4×1038입니다.

따라서 데이터 손실이 없다 할 수 없습니다.

0

baljang

범위가 float이 더 넓긴 하지만 방식 자체가 다르기 때문에 변환할 때 손실이 생기는 것인가 보군요. 감사합니다. 

visualstudio에서 파일분할관리실습시 설정 문의를 드립니다.

0

559

1

정렬함수 좀 더 확실하게 이해 할 방법이 있을까요?

0

453

1

strcpy() 구현 관련 질문

0

533

1

빌드(망치)를 누르니 이런 오류가 떴습니다. 어떻게 해야 하나요?

0

475

1

클래스 타입의 포인터 질문합니다

0

559

1

입력값을 enum 값에 넣어주는거 이제 막혔나요?

0

503

1

템플릿 특수화 관련 질문

0

389

1

포인터 관련 질문합니다!

0

270

1

Unable to start assembler. Check your settings.

0

848

2

cpu선택

0

548

1

포인터 질문이 있습니다

0

331

1

20:35 에서 구조체 크기에 대한 질문입니다!

0

589

1

iterator 삭제관련

0

415

1

함수 호출을 디스어셈블러로 분석하다가 궁금점이 생겼습니다!

0

316

1

15 분 45초 대 질문

0

317

0

스택 프레임 질문합니다!

2

312

1

오른값 참조 in 게임

0

391

0

동적할당 질문이 있습니다

0

457

1

안녕하세요 메모리에 대해 질문드립니다.

0

312

1

함수객체 의 매개변수

0

365

1

복사생성자

0

439

1

main이나 endl 부분이 주황색으로 표시된건 어떻게 하나요

0

430

1

포인터 실습 강의를 보고 궁금한게 있습니다.

0

359

1

스택 오버플로우

2

801

1