0.1F + 0.1F 에서 오차가 나는 이유
부동소수점 오차 관련하여 질문이 있습니다.
부동소수점 방식에서 순환소수를 표현할 때는 오차가 난다는 것을 이해하였습니다.
하지만 0.1은 순환소수가 아니어서 부동소수점 방식으로도 정확하게 표현할 수 있는데, 강의에서처럼 오차가 나는 이유가 무엇인가요?
답변 1
1
컴퓨터의 구조가 그렇기 때문입니다. 컴퓨터의 CPU가 부동소수점을 표현하는 방법은 IEEE 754 표준에 근거합니다. 이 때문에 부동소수점 오차 문제는 모든 프로그래밍 언어에서 공통으로 발생하는 문제라 할 수 있습니다. 이 IEEE 754에 대한 내용은 그것만 설명하더라도 상당한 시간이 필요합니다. 댓글로 간단히 답변을 드리기가 어려우므로 관련 내용을 찾아보실 것을 권장드립니다. 감사합니다. 😄
sizeof는 컴파일 타임 연산자라서 CPU를 사용치 않는다
0
29
2
scanf("%d\n") 의미
0
47
2
주소 연산자(&) 간접 지정자(*) 반대 개념
0
62
2
Virtual Memory, Memory, Memory mapping tables
0
80
2
샘플코드 출력 오류 발생 질문드립니다
0
82
2
값의 교환에 사용되는 변수의 위치.
0
106
2
메모리 비교에 관한 질문
0
92
2
문자열 Null
0
69
1
C, C++
0
101
2
문자열 입출력 코드 에러
0
72
2
선생님! 120화 2분 50초 질문입니다.
0
75
1
caller 가 메모리 할당 해제를 할 때의 문제점 질문
0
70
2
단축키 맞는지 여부 문의드립니다.
0
66
2
문자열을 사용하는 이중 포인터에 대하여 질문합니다
0
72
1
char 포인터 변수의 크기에 대하여 제가 이해한 것이 맞을까요
0
84
2
용어 설명 필요
0
63
2
stdin, stdout
0
76
2
필수 실습 (최댓값을 반환하는 함수)
0
99
2
아......ㅠㅠ
0
108
2
버퍼 내 엔터
0
80
1
2진수 뺄셈에서 carry-out
0
126
2
union 식별자는 실무에서 보통 어디에서 사용하나요?
0
89
2
필수실습문제 공부법 (진도 vs 복습)
0
114
2
예제파일 다운로드
0
87
2





