본문으로 건너뛰기
피드

C enum 크기 문제: MSVC가 또 표준을 무시하는 건에 대하여

backend 약 3분
vote
0
댓글
북마크

C23 enum에서 2³² 이상 값을 쓰면 GCC/Clang은 64비트로 확장하지만, 최신 MSVC는 32비트에 고정되어 값이 0으로 잘림. C23 기저 타입 어노테이션도 미지원.

  • 1

    GCC/Clang은 enumerator 값에 따라 자동으로 64비트 확장

  • 2

    MSVC 14.50(VS 2026)에서 2³² 이상 값이 조용히 0으로 잘림

  • 3

    C23 기저 타입 어노테이션을 MSVC가 지원하지 않음

  • 4

    대안: long long + 상수 사용, 또는 struct 래핑

  • C 언어에서 enum의 크기가 컴파일러마다 다르게 동작하는데, MSVC가 또 표준을 무시하는 사례 발견

  • C23부터 enum에 기저 타입을 명시할 수 있게 됨 (enum Composer: int { ... }). 명시하지 않으면 컴파일러가 char부터 long long까지 알아서 선택 가능한데, 이게 표준 준수 범위 안에 있음

  • GCC와 Clang은 정상 동작함. enumerator 값이 2³²-1을 초과하면 자동으로 64비트로 확장. 예를 들어 VaughanWilliams = 4294967296(2³²)을 넣으면:

    • GCC/Clang: 값 4294967296 출력, 크기 64비트 ✅
    • MSVC: 값 0 출력, 크기 32비트

⚠️주의

> 최신 Visual Studio 2026(MSVC 14.50)에서도 이 문제가 발생함. C23의 기저 타입 어노테이션도 지원하지 않음. "실험적 ISO C23 지원"을 켜도 마찬가지

  • 이게 런타임 에러로 이어질 수 있다는 게 진짜 무서운 부분. 값이 조용히 0으로 잘려버리니 디버깅하기 어려운 버그가 됨

  • 실용적 대처법:

    • MSVC를 써야 하면 2³² 이상 값이 필요한 enum 대신 long long + 상수를 사용
    • 타입 안전성이 필요하면 값을 감싸는 struct를 고려
    • MSVC 지원하는 C 라이브러리를 쓰고 있다면 모든 enum이 32비트라고 가정해도 무방
    • Rust에서 C FFI 쓸 때는 bindgen이 적절한 std::ffi::c_xxx 타입을 잡아줌

크로스 플랫폼 C 코드를 작성할 때 MSVC의 enum 구현을 절대 신뢰하지 말 것. 특히 Rust FFI에서 bindgen이 타입을 자동으로 잡아주는 것도 참고할 만함.

댓글

댓글

댓글을 불러오는 중...

backend

Go에서 Rust로 옮길 때 진짜로 바뀌는 것들

이 글은 Go 백엔드 서비스를 Rust로 옮길 때 속도보다 컴파일 타임 보장, 런타임 트레이드오프, 개발자 경험이 더 중요하다고 설명한다. nil 패닉, 데이터 레이스, 에러 처리, 제네릭, 비동기 모델, 마이그레이션 전략까지 실무 관점에서 Go와 Rust를 길게 비교한다.

backend

Python 3.15에서 헤드라인은 못 탔지만 꽤 쓸만한 기능들

Python 3.15에는 lazy imports나 Tachyon profiler 같은 큰 기능 말고도 실무에서 바로 체감될 만한 작은 개선들이 들어가. TaskGroup 취소, 컨텍스트 매니저 데코레이터 개선, 스레드 안전 이터레이터처럼 평소 애매하게 불편했던 지점들이 꽤 깔끔해졌어.

backend

심평원, DUR부터 의료영상 심사까지 클라우드로 갈아엎는다

심평원이 정보시스템 클라우드 전환과 함께 병·의원 업무에 직접 닿는 DUR, 의료영상 AI 심사, 요양급여내역 조회 시스템을 고도화한다. 핵심은 설치형 프로그램 중심이던 연계를 웹과 API 기반으로 넓히고, 진료·청구 과정에서 실시간 확인과 자동 판독을 강화하는 쪽이다.

backend

윈도우 에러 코드 7번 ‘ERROR_ARENA_TRASHED’는 어디서 왔을까

ERROR_ARENA_TRASHED는 Win32에서 실제로 쓰이는 현대적 에러라기보다 MS-DOS 시절 메모리 관리 구조에서 넘어온 잔재야. MS-DOS가 메모리 블록 앞의 arena 시그니처를 훑다가 예상한 값이 아니면 ‘arena가 망가졌다’고 보고 이 에러를 냈다는 이야기야.

backend

C/C++ 컴파일러의 느슨한 메모리 동시성 버그를 자동으로 잡는 박사논문

C와 C++ 컴파일러에서 relaxed memory 동시성 버그를 찾는 자동 테스트 프레임워크를 다룬 박사논문이 공개됐어. Téléchat, Atomic-mixer 같은 도구로 소스 수준 동작과 컴파일된 프로그램 동작을 비교하고, LLVM과 GCC 툴체인에서 실제 버그를 찾아낸 내용이 핵심이야.