inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

독하게 시작하는 C 프로그래밍

부동소수점 오차

0.1F + 0.1F 에서 오차가 나는 이유

해결된 질문

297

choimk0512

작성한 질문수 1

0

부동소수점 오차 관련하여 질문이 있습니다.

부동소수점 방식에서 순환소수를 표현할 때는 오차가 난다는 것을 이해하였습니다.

하지만 0.1은 순환소수가 아니어서 부동소수점 방식으로도 정확하게 표현할 수 있는데, 강의에서처럼 오차가 나는 이유가 무엇인가요?

c 부동소수점

답변 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