Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Warning C6262 Function uses '65564' bytes of stack: exceeds /analyze:stacksize '16384'. Consider moving some data to heap.

아래와 같은 코드를 빌드하면,

#define SIZE 65536

static int check(char* file)
{
    uint8_t buffer[SIZE];
}

컴파일 시, 이런 경고가 뜹니다.

Warning C6262 Function uses '65564' bytes of stack:  exceeds /analyze:stacksize '16384'.  Consider moving some data to heap.

문서에도 나오지만,

C6262
; https://learn.microsoft.com/en-us/cpp/code-quality/c6262

User mode의 응용 프로그램을 개발할 때는 무시해도 상관없습니다. 컴파일러마다 다르지만 보통은 기본 스택 크기가 1MB이고, 또한 그 크기도 원한다면 늘릴 수 있기 때문에 64KB의 스택을 할당하는 것이 크게 문제가 되지 않을 수 있습니다.

그런데도 이런 경고를 띄우는 것은, 어쨌든 스택을 과다하게 사용하는 것은 좋지 않으므로 16KB가 넘어가는 스택 할당에 대해서는 힙 할당을 권장하는 것뿐입니다.

일단, Visual C++의 경우 컴파일 경고는 다음과 같이 "C++" 옵션에서 새로운 크기를 지정하는 것으로 가능합니다.

c6262_warn_1.png

/analyze:stacksize 65564 

하지만, 그래도 "Error List" 창에서의 경고는 없애지 못합니다.

c6262_warn_2.png

아마도 이것은 "Analyzer"가 정적 분석으로 보여주는 것이므로 C++의 컴파일 옵션을 조정하는 것이 반영되지 않는 듯합니다. 따라서, 깔끔하게 없애려면 결국 스택이 아닌 힙 할당으로 바꿔야 합니다.




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







[최초 등록일: ]
[최종 수정일: 12/22/2022]

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

비밀번호

댓글 작성자
 



2022-12-22 11시05분
[나그네] 변경한 스택사이즈를 65564로 하신 특별한 이유가 있으신가요? 궁금해서 여쭤봅니다
[guest]
2022-12-22 12시33분
11개월 전에 쓴 내용이라... 그때 왜 그랬는지 기억이 잘 안 납니다. ^^;
정성태

... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12299정성태8/27/202021320.NET Framework: 934. C# - ETW 관련 Win32 API 사용 예제 코드 (3) ETW Consumer 구현파일 다운로드1
12298정성태8/27/202021308오류 유형: 640. livekd - Could not resolve symbols for ntoskrnl.exe: MmPfnDatabase
12297정성태8/25/202020799개발 환경 구성: 503. SHA256 테스트 인증서 생성 방법
12296정성태8/24/202022091.NET Framework: 933. C# - ETW 관련 Win32 API 사용 예제 코드 (2) NT Kernel Logger파일 다운로드1
12295정성태8/24/202020903오류 유형: 639. Bitvise - Address is already in use; bind() in ListeningSocket::StartListening() failed: Windows error 10013: An attempt was made to access a socket ,,,
12293정성태8/24/202021641Windows: 171. "Administered port exclusions" 설명
12292정성태8/20/202025125.NET Framework: 932. C# - ETW 관련 Win32 API 사용 예제 코드 (1)파일 다운로드2
12291정성태8/15/202021399오류 유형: 638. error 1297: Device driver does not install on any devices, use primitive driver if this is intended.
12290정성태8/11/202023114.NET Framework: 931. C# - IP 주소에 따른 국가별 위치 확인 [8]파일 다운로드1
12289정성태8/6/202019899개발 환경 구성: 502. Portainer에 윈도우 컨테이너를 등록하는 방법
12288정성태8/5/202017348오류 유형: 637. WCF - The protocol 'net.tcp' does not have an implementation of HostedTransportConfiguration type registered.
12287정성태8/5/202020243오류 유형: 636. C# - libdl.so를 DllImport로 연결 시 docker container 내에서 System.DllNotFoundException 예외 발생
12286정성태8/5/202022087개발 환경 구성: 501. .NET Core 용 container 이미지 만들 때 unzip이 필요한 경우
12285정성태8/4/202020131오류 유형: 635. 윈도우 10 업데이트 - 0xc1900209 [2]
12284정성태8/4/202019532디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법
12283정성태8/3/202021738디버깅 기술: 168. windbg - 필터 드라이버 확인하는 확장 명령어(!fltkd) [2]
12282정성태8/2/202018435디버깅 기술: 167. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash (2)
12281정성태8/2/202022907개발 환경 구성: 500. (PDB 연결이 없는) DLL의 소스 코드 디버깅을 dotPeek 도구로 해결하는 방법
12280정성태8/2/202019872오류 유형: 634. 오라클 (평생) 무료 클라우드 VM 생성 후 SSH 접속 시 키 오류 발생 [2]
12279정성태7/29/202022954개발 환경 구성: 499. 닷넷에서 접근해보는 InterSystems의 Cache 데이터베이스파일 다운로드1
12278정성태7/23/202018544VS.NET IDE: 149. ("Binary was not built with debug information" 상태로) 소스 코드 디버깅이 안되는 경우
12277정성태7/23/202020868개발 환경 구성: 498. DEVPATH 환경 변수의 사용 예 - .NET Reflector의 (PDB 연결이 없는) DLL의 소스 코드 디버깅
12276정성태7/23/202020884.NET Framework: 930. 개발자를 위한 닷넷 어셈블리 바인딩 - DEVPATH 환경 변수
12275정성태7/22/202022494개발 환경 구성: 497. 닷넷에서 접근해보는 InterSystems의 IRIS Data Platform 데이터베이스파일 다운로드1
12274정성태7/21/202021240개발 환경 구성: 496. Azure - Blob Storage Account의 Location 이전 방법 [1]파일 다운로드1
12273정성태7/18/202024727개발 환경 구성: 495. Azure - Location이 다른 웹/DB 서버의 경우 발생하는 성능 하락
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...