float 질문있습니다!
float f = 3.1412345089f;
이 출력이 3.1412344 이렇게 나오는데
마지막 자리가5가 아니라 4인 이유가 뭔가요???
답변 1
0
안녕하세요?
0 과 1 사이에는 0.1, 0.01, 0.001, 0.0001, 0.00001, ... 등 무한히 많은 실수가 존재할 수 있습니다. 하지만 컴퓨터는 데이터를 저장하기 위해 주어진 공간 내에서 소수점 이하 아주 깊은 자릿수까지 모두 올바로 표현할 수는 없기 때문에 정확한 값보다는 근사한 값으로 실수를 표현하고 있으며 이 과정에서 일부 오차가 발생할 수밖에 없습니다. 그래서 질문주신 예시에서는 3.141234 까지는 올바로 표현되지만 그 이하 자리는 입력한 데이터와 다르게 나오는 것입니다. 실수형 자료에는 정밀도(precision) 라고 하는 게 있는데 float 의 경우 10진수 7자리를, double 의 경우 15자리를 올바르게 저장할 수 있습니다. 이와 관련해서 더 공부하고 싶으신 경우 구글에서 '부동 소수점'으로 검색해보시면 보다 자세한 자료를 찾으실 수 있습니다.
결론적으로는 컴퓨터에서 실수를 표현하는 과정에서 오차가 발생할 수 있으니 보다 정밀한 실수의 연산을 필요로 하는 경우에는 float 대신 double 의 사용을 권장드립니다.
감사합니다.
자바를 처음 배울 때 이런 고민이 드는 게 정상일까요?
1
148
2
static이 뭐였는지 기억이 안나요 ㅜㅜ
0
120
2
Iterator (알 수 없음) 데이터 삭제 후 초기화 관련 문의
0
73
1
사고력 키우는 법이 어떤게 있나요?
0
94
2
getter setter
0
103
2
섹션9. 66 메소드 오버로딩 시 질문이 있습니다.
0
80
1
안녕하세요 갑자기 프로그램 에러가 떠서 안되네요
0
77
2
변수 이름짓는법
0
114
2
intelli J 실행오류
0
115
2
혹시 이건 수학적 사고가 부족한 걸까요?
0
152
2
영상이 재생이 안됩니다.
0
167
3
이중 반복문 (후반전) 오른쪽으로 치우친 별 쌓기에 질문이 있습니다.
0
118
2
응용이 어렵습니다.
0
207
2
IntelliJ가 보이지 않습니다.
0
187
3
JDK 버전 문의
0
130
2
BlackBox 파일 내에서 메소드 정의
0
137
1
동기화
0
123
2
Iterator 문의
0
105
1
코드 순서 문의
0
143
1
클래스 메소드
0
150
2
Quiz_05 관련 질문드립니다 !
0
118
2
다운로드가 안됩니다
0
165
2
다형성
0
120
2
HashMap
0
82
2





