Microsoft MVP성태의 닷넷 이야기
오류 유형: 544. C++ - fatal error C1017: invalid integer constant expression [링크 복사], [링크+제목 복사],
조회: 20043
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

C++ - fatal error C1017: invalid integer constant expression

C++의 #if 전처리 구문은,

#if, #elif, #else, and #endif Directives (C/C++)
; https://learn.microsoft.com/en-us/cpp/preprocessor/hash-if-hash-elif-hash-else-and-hash-endif-directives-c-cpp?view=vs-2019

해당 매크로가 정의된다면 반드시 정수 상수식임을 요구합니다. 만약 이를 만족시키지 못하면 C1017 컴파일 오류가 발생하는데요.

Fatal Error C1017
; https://learn.microsoft.com/en-us/cpp/error-messages/compiler-errors-1/fatal-error-c1017?view=vs-2019

문제는, 해당 매크로 상수가 정의되지 않았을 때에는 정수 상수식이 아니어도 된다는 점입니다.

#if _MYHEADER_H
short t1 = 5;
#else
#define _MYHEADER_H
short t1 = 5;
#endif

즉, 위의 상황에서는 "#if" 다음의 _MYHEADER_H 상수가 정의되지 않은 상태이므로 오류 없이 컴파일됩니다. 하지만, 일단 상수가 정의되었으면 그것은 반드시 정숫값을 가져야만 합니다. 위에서 "#define _MYHEADER_H"와 같이 하면 일단은 통과하는 듯 싶어도 다음과 같이 코드가 반복되면 여지없이 두 번째에서 C1017 오류가 발생합니다.

#if _MYHEADER_H
short t1 = 5;
#else
#define _MYHEADER_H
short t1 = 5;
#endif

#if _MYHEADER_H // fatal error C1017: invalid integer constant expression
short t1 = 5;
#else
#define _MYHEADER_H
short t1 = 5;
#endif

물론, 현업에서 저런 식으로 두 번 연이어 사용하는 경우는 거의 없을 것입니다. 단지 헤더 파일을 정의하는 과정에서 ("#pragma once" 처리를 실수로 누락한... 등의 사유로) #include가 다층으로 꼬이게 되면 저 오류가 어느 순간 돌연 발생하게 됩니다.

만약 위와 같은 상황을 C# 언어도 잘 사용하는 개발자에게 발생한다면... C#에서는 다음과 같은 처리가 정상적으로 처리되기 때문에,

#if _MYHEADER_H
#else
#define _MYHEADER_H
public class Test { }
#endif

#if _MYHEADER_H
public class Test2 { }
#else
#define _MYHEADER_H
#endif

이유를 찾지 못해 헤매는 경우가 나옵니다... 저처럼. ^^;

(첨부 파일은 C1017 오류가 재현되는 Visual C++ 예제입니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 3/9/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... [181]  182  183  184  185  186  187  188  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
492정성태5/23/200726607.NET Framework: 89. ManagedThreadId - 두 번째 이야기 [5]파일 다운로드1
491정성태5/21/200726728.NET Framework: 88. ManagedThreadId ? [4]
490정성태5/19/200735221오류 유형: 33. error MSB6003: SxS DLL 로딩 오류 [2]
489정성태5/14/200723049.NET Framework: 87. .NET 2.0에서 C# 3.0 기능 사용하기
488정성태5/14/200721604Windows: 25. Multiple Input Queues
487정성태4/24/200727212VC++: 32. VC++에서 bool이 가지는 의미 [3]
486정성태3/22/200726238Windows: 24. DreamScene과 DWM(Desktop Window Manager)의 관계 [1]
485정성태3/17/200721556오류 유형: 32. VS.NET 2005 - x64 환경에서의 mixed 디버깅 환경 구성
484정성태3/17/200720726오류 유형: 31. SQL Compact Edition 설치 후 오류
483정성태3/17/200742130오류 유형: 30. x64 환경: .NET + COM 프로젝트 실행 시 오류 - 80040154 [2]
482정성태3/17/200731631Team Foundation Server: 17. 팀 프로젝트 접속 및 사용
481정성태3/17/200725549Team Foundation Server: 16. 팀 프로젝트 읽기 전용 사용자 등록
480정성태3/14/200723794.NET Framework: 86. GC(Garbage Collector)의 변화
479정성태3/14/200727619개발 환경 구성: 25. D820 - ReadyBoost 구동
478정성태3/14/200727091개발 환경 구성: 24. D820 고주파음 문제
477정성태3/14/200736350개발 환경 구성: 23. 비스타 x64 버전에서 서명되지 않은 드라이버 사용 [4]
476정성태3/9/200731825개발 환경 구성: 22. D820 노트북 - 설치 및 BitLocker 구성 [1]
475정성태3/6/200726206.NET Framework: 85. 공용 프로퍼티 자동 생성
474정성태3/5/200724447.NET Framework: 84. Lambda 표현식 응용 사례 [1]
473정성태3/4/200731485디버깅 기술: 14. TFS 오류 추적(TF53010, TF14105)
472정성태3/3/200730717디버깅 기술: 13. 예외 발생 시 Minidump 생성 - WinDBG [3]파일 다운로드1
471정성태3/1/200719760디버깅 기술: 12. Managed Method에 Break Point 걸기
469정성태2/28/200731372디버깅 기술: 11. (Managed) Main Method에 Break Point 걸기 [3]파일 다운로드1
470정성태3/1/200722806    답변글 디버깅 기술: 11.1. (Managed) Main Method에 Break Point 걸기 - 내용 보강
468정성태2/25/200732549COM 개체 관련: 20. 탭 브라우저의 윈도우 핸들 구하기 [3]
466정성태2/22/200724390Windows: 23. 롱혼 서버 코어 버전 [2]
... [181]  182  183  184  185  186  187  188  189  190  191  192  193  194  195  ...