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개월 전에 쓴 내용이라... 그때 왜 그랬는지 기억이 잘 안 납니다. ^^;
정성태

... 121  122  123  124  125  126  127  128  129  130  131  132  133  [134]  135  ...
NoWriterDateCnt.TitleFile(s)
1704정성태7/2/201421631.NET Framework: 447. w3wp.exe AppPool 재생(recycle)하는 방법 정리
1703정성태7/2/201422467.NET Framework: 446. Assembly.Load를 이용해 GAC에 등록된 어셈블리를 로드하는 방법 [1]파일 다운로드1
1702정성태6/23/201422184Phone: 11. Xamarin.Forms - 2. XAML을 이용한 페이지 개발파일 다운로드1
1701정성태6/23/201434370개발 환경 구성: 229. .NET Reflector + Reflexil 도구를 이용해 DLL 코드 변경 [4]
1700정성태6/23/201421218VS.NET IDE: 89. Visual Studio에서 기본 제공되는 성능 프로파일 [2]
1699정성태6/22/201424025Phone: 10. Xamarin.Forms - 1. Forms 시작하기 [2]파일 다운로드1
1698정성태6/22/201426020.NET Framework: 445. [부연 설명] 쉬운 C# 코드를 어럽게 이해하기 [2]
1697정성태6/22/201421269VS.NET IDE: 88. Visual Studio에서 직접 컴파일하는 IL 언어 확장 도구 - IL Support
1696정성태6/22/201421103.NET Framework: 444. clojure와 C#을 통해 이해하는 Sequence와 Vector 형식의 차이점 [1]
1695정성태6/21/201420111개발 환경 구성: 228. PowerShell ISE에서 (입력 기능이 있는) 콘솔 응용 프로그램을 시작하는 방법
1694정성태6/21/201421267개발 환경 구성: 227. 닷넷 용 ClojureCLR 개발환경 설정
1693정성태6/20/201421606개발 환경 구성: 226. Clojure 언어의 윈도우 개발환경 설정
1692정성태6/19/201432212오류 유형: 231. Visual Studio 2013 한글 버전 설치 오류 - The form specified for the subject is not one supported or known by the specified trust provider
1691정성태6/18/201427423개발 환경 구성: 225. 유닉스 계열의 tail 명령어가 제공되는 PowerShell [1]
1690정성태6/18/201430204개발 환경 구성: 224. DirectShow 예제 구하는 방법 [3]
1689정성태6/18/201427039오류 유형: 230. C++ 가변 인자 사용시 va_start 파라미터 전달 방법 [2]
1688정성태6/15/201420599오류 유형: 229. 갤럭시 노트 3 환경에서 Xamarin 앱 배포 충돌
1687정성태6/15/201426622개발 환경 구성: 223. PowerShell로 Visual Studio 빌드 스크립트 작성파일 다운로드1
1686정성태6/12/201424309Windows: 96. 윈도우 8 - 그림 암호를 이용해 로그인 시 지연 현상을 해결하는 방법 [1]
1685정성태6/10/201431078.NET Framework: 443. 자바 8과 C#의 람다(Lambda) 지원에 대한 비교 [12]
1684정성태6/9/201441241.NET Framework: 442. C# - 시스템의 CPU 사용량 및 프로세스(EXE)의 CPU 사용량 알아내는 방법 [5]파일 다운로드1
1683정성태6/2/201420777오류 유형: 228. CLR4 보안 - yield 구문 내에서 SecurityCritical 메서드 사용 불가 [2]파일 다운로드1
1682정성태6/1/201426010.NET Framework: 441. .NET CLR4 보안 모델 - 3. CLR4 보안 모델에서의 APTCA 역할파일 다운로드2
1681정성태6/1/201421857.NET Framework: 440. .NET CLR4 보안 모델 - 2. 샌드박스(Sandbox)을 이용한 보안 [2]파일 다운로드1
1680정성태6/1/201421339.NET Framework: 439. .NET CLR4 보안 모델 - 1. "Security Level 2"란?파일 다운로드1
1679정성태5/31/201420453.NET Framework: 438. .NET CLR2 보안 모델에서의 APTCA 역할파일 다운로드1
... 121  122  123  124  125  126  127  128  129  130  131  132  133  [134]  135  ...