윈도우에서 경고조차 없는데, 리눅스에서 에러나는 코드입니다. 도움 부탁 드립니다.
글쓴이: tyolee83 / 작성시간: 수, 2007/12/26 - 6:21오후
수학적 연산이 필요한 프로그램을 윈도우에서 리눅스로 포팅하는 중에 문제가 발생했습니다.
다음과 같은 코드가 있습니다.
static const double PI=3.141592653589793238462643383279502884197169399375105820975;
윈도우에서는 경고 조차 없이 잘 넘어 갑니다.
그런데 g++은 다음과 같은 에러를 냅니다.
expected unqualified-id before numeric constant
이 메세지를 구글에 검색해봐도 마땅한 결과를 찾을 수가 없네요....
윈도우에서 경고조차 없는 코드가 g++에서 에러가 나는것도 처음 보는데..
혹시 이유를 아시는분 도움좀 부탁드립니다.
감사합니다.
Forums:
방금 #include int
방금
라고 쓰고 테스트 해봤는데 아무런 경고나 에러 없이 실행되었습니다.
그리고 double은 유효숫자가 15자리인걸로 알고 있습니다. 저렇게 길게 적어봤자 어차피 double에 넣는 순간 소숫점 15자리 아래 숫자는 짤려버리니 저리 길게 적어도 아무런 의미가 없지 않나요?
에러 내용은 구글링해보니 주로 #define으로 정의된 상수를 변수로 사용하려 할때 발생하는듯 하네요.
어딘가에서 PI 라는 이름의 매크로 상수를 정의했거나 include한 라이브러리중에 PI를 매크로 상수로 정의한게 없나 확인해보세요.
라이브러리에 미리
라이브러리에 미리 정의되어 있었군요.
감사합니다. :)
==========================
Toward Fully Understanding
//TODO
그런데, 아무래도
그런데, 아무래도 math.h 혹은 cmath에 정의된 M_PI를 쓰는 게 정답 아닐까요?
revision2008, formally known as cppig1995
Real programmers /* don't */ comment their code.
If it was hard to write, it should be /* hard to */ read.
워우~
와우 틀린 말입니다. double 은 IEEE 745의 double precision 에 정의 되어 있고 표현가능한 숫자는 어마어마합니다. 다만 정확하지 않을 뿐이죠.
http://en.wikipedia.org/wiki/IEEE_754
Dig it.
double precision
double precision 기준으로 fraction 파트가 52bit이니,
대략 유효숫자가 16자리를 넘어가면 표현할 수 없죠.
유효숫자는
x.xxxxx * 10^y
와 같은 표기에서 x를 얼마나 길게 적을 수 있느냐의 문제입니다.
큰 숫자를 표현하는 것(y를 키우는 것)과 착각하신 것 같습니다.
에 정의된 DBL_DIG 값을
에 정의된 DBL_DIG 값을 말하는 것입니다.
댓글 달기