inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

3.12 부동소수점형의 한계

3.12 강의 수학적으로 존재하지 않는 식을 강행했을 때

259

qptm

작성한 질문수 1

1

안녕하세요. 비주얼 스튜디오에서 선생님과 똑같이 asinf() 코드를 작성하고 실행을 했는데 선생님 화면에서 나온

1.570796

-nan(ind)

대신에

8096.000000

8096.000000

이렇게 나옵니다. 뭐가 잘못된걸까요?

c

답변 1

1

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

 

int main()
{
  float f = asinf(1.0f);
  printf("%f\n", f);

  f = asinf(2.0f);
  printf("%f\n", f);

  return 0;
}

위의 예제 코드로 직접 실행해보니, 강의와 동일한 결과(1.570796, -nan)가 출력되는 것을 확인했습니다.

혹시, 인수로 작성하신 값에 오타가 발생하지는 않으셨는지 확인해보시면 좋을 것 같습니다.
또한, 질문자님께서 작성하신 코드를 공유해주시면 제가 더 구체적으로 도움을 드릴 수 있을 것 같습니다.

1

qptm

imageimage

안녕하세요. 제가 기존에 작성했던 코드 사진와 실행시 나오는 화면 사진을 첨부합니다. 제가 놓친 부분이 있을까요?

0

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

 

asinf() 함수의 인수는 강의의 코드와 일치합니다.

asinf(1.0f) 의 호출은 π/2 라디안 값을 반환하여 약 1.570796에 해당하고, asinf(2.0f) 호출의 경우 인수의 범위가 함수의 정의 범위를 벗어나므로, NaN 값을 반환해야 합니다.

두 번째 경우에는 8096.000000 이라는 비정상적인 값이 컴파일러나 실행 환경에 따른 에러 처리 방식이 다를 수 있기 때문으로(예상치 못한 동작) 이해하려고 해도, 첫 번째 경우에서도 이상한 값이 나오는 것은 저도 이유를 유추하기 어렵네요. 🥲🥲

혹시, asinf() 함수가 정의되어 있는 헤더 파일, 즉 #include <math.h> 를 추가하셔서 결과를 확인해보시면 감사하겠습니다.

Export template 안됨

1

19

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

54

3

main 함수에서 왜 int만 선언이 되는걸까요

1

56

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

54

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

49

1

프로토타입과 함수간의 인자 불일치

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

137

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

61

2

getchar(), putchar()

1

93

3

강의자리ㅛ

1

80

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

113

2

소스파일안에 여러 파일

1

76

2

F5와 F7의 차이

1

76

2

c = TWO * (a+b); 에서 a와 b는?

1

58

2

; 세미콜론을 붙이는 기준에 문의

1

69

1

Step over 기능 문의

1

53

2

2.6 강의 따옴표 출력 규칙 문의

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

65

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

53

2