Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 1. VC++ 프로파일링 사용법 [링크 복사], [링크+제목 복사],
조회: 29910
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

혹시, 이글을 읽어보시는 분들중에 EXE 프로젝트의 프로파일링을
MSDN 보시면서 해보신 분 계신가요?

그 메뉴얼 대로 해보시면... ^^ 안되더군요.
에러가 납니다.

PREP : fatal error PRF1011: cannot open file
c:\workshop\texen\test\debug\test.pbo

위와 같은 에러가 나죠.

아,,, 그전에 사용을 위한 환경설정부터 설명을 해야 겠네요.

1. Project/Settings 메뉴를 선택합니다.
2. Link 탭으로 이동합니다.
3. Enable Profiling 를 체크합니다.
4. 재컴파일을 합니다.

위의 4단계를 하면 설정은 완료된 것입니다.

그럼, 프로파일링을 해야 되는데요. 그것도 역시 간단합니다.
1. Build 메뉴를 선택합니다.
2. 가장 하단의 "Profile" 메뉴가 활성화되어 있는 것을 발견할 수 있
습니다. 선택합니다.
3. 원하는 타입의 프로파일링을 선택하고 "OK" 를 누릅니다.

그럼, 실행파일이 실행이 되고, 평소처럼 동작시킨 후, 종료를
시키면 됩니다.

종료되는 순간에, 모든 결과값을 통합환경의 하단에 있는
"Output" 윈도우에 "Profile" 이란 탭에서 출력이 되도록 되어 있습니
다.


직접... 해보십시오.
근데... 말씀드린 것 처럼, 위의 에러가 날 것입니다.
어쨌든, 믿을 것은 MSDN 라이브러리 밖에 없고요. 이것저것 조합을 해
보면서 시도를 해봤습니다.

결론은, 안됩니다. ^^
VC++ 통합환경에서 미리 제공된 옵션으로는 안되고요.
거기 프로파일 창에 보면 "Custom" 이란 라디오 버튼이 있을 것입니
다. 그걸 통해서만이 제대로 프로파일링을 할 수 있습니다.

1. 아래와 같이 test.bat 을 만듭니다.
    PREP /OM /FT %1
    PROFILE test._xe
    PREP /M %1
    PLIST /SC /ST %1
2. 위에서 test._xe 라고 되어 있는 부분을 자신의 프로젝트에 맞게
수정합니다. 예를 들어 여러분이 만든 프로젝트의 결과 EXE 파일이
proftest.exe 가 나온다면, 위의 "test._xe" 부분을 "proftest._xe"
라고 수정하시면 됩니다.
3. test.bat 을 저장해 둡니다.
4. Build 메뉴를 선택합니다.
5. 가장 하단의 "Profile" 메뉴가 활성화되어 있는 것을 발견할 수 있
습니다. 선택합니다.
6. "Custom" 을 선택하면, Custom Setting" 가 활성화됩니다. 눌러
서, [3] 번 단계에서 저장해둔 test.bat 을 지정합니다.
7. "OK" 버튼을 누릅니다.

위와 같이 하고, 실행된 응용 프로그램을 종료시키면,
하단 "Output" 창의 "Profile" 탭에는 결과가 출력되는 것을 볼 수 있
습니다.

위의 결과로 예상하는 건데요. VC++ 자동 프로파일링에서는
PROFILE test._xe

PROFILE test.exe
로 실행을 시키는 바람에 제대로 프로파일링이 안되는 것 같습니다.









[최초 등록일: ]
[최종 수정일: 7/17/2003]

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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
14038정성태11/6/2025790Linux: 130. eBPF - bpf_skb_load_bytes를 이용한 __sk_buff.data 영역의 IP/TCP 헤더 해석
14037정성태11/3/2025666Linux: 129. eBPF (bpf2go) - BPF_PROG_TYPE_CGROUP_SKB 예제 - "cgroup_skb/egress", "cgroup_skb/egress"
14036정성태10/25/20251663디버깅 기술: 224. Visual Studio - 디버깅 시 다른 함수의 소스 코드를 보여주는 사례 (Enable COMDAT Folding 옵션)파일 다운로드1
14035정성태10/24/20251653C/C++: 189. Visual C++ - 디버그 코드에서 빌드 옵션 조정으로 최적화 코드로의 전환파일 다운로드1
14034정성태10/22/20251621닷넷: 2375. C# - dynamic 사용 시 internal 멤버에 대한 RuntimeBinderException 예외가 발생하는 문제파일 다운로드1
14033정성태10/22/20252079닷넷: 2374. C# - dynamic과 "Explicit Interface Implementation"의 문제파일 다운로드1
14032정성태10/21/20251723닷넷: 2373. C# - dynamic 예약어 사용 시 런타임에 "Microsoft.CSharp.RuntimeBinder.RuntimeBinderException" 예외가 발생하는 경우파일 다운로드1
14031정성태10/20/20251640Linux: 128. "USER ..." 설정이 된 Docker 컨테이너의 호스트 측 볼륨 권한 (2)
14030정성태10/20/20251926Linux: 127. "USER ..." 설정이 된 Docker 컨테이너의 호스트 측 볼륨 권한
14029정성태10/17/20252707닷넷: 2372. C# - ssh-ed25519 유형의 Public Key 파일 해석파일 다운로드1
14028정성태10/17/20252882오류 유형: 985. openssh - ssh_host_ed25519_key 파일을 로드하지 못하는 문제
14027정성태10/15/20252706닷넷: 2371. C# - CRC64 (System.IO.Hashing의 약식 버전)파일 다운로드1
14026정성태10/15/20252959닷넷: 2370. 닷넷 지원 정보의 "package-provided" 의미
14025정성태10/14/20252856Linux: 126. eBPF (bpf2go) - tcp_sendmsg 예제
14024정성태10/14/20253443오류 유형: 984. Whisper.net - System.Exception: 'Cannot dispose while processing, please use DisposeAsync instead.'
14023정성태10/12/20253543닷넷: 2369. C# / Whisper 모델 - 동영상의 음성을 인식해 자동으로 SRT 자막 파일을 생성 [1]파일 다운로드1
14022정성태10/10/20253882닷넷: 2368. C# / NAudio - (AI 학습을 위해) 무음 구간을 반영한 오디오 파일 분할파일 다운로드1
14021정성태10/6/20254278닷넷: 2367. C# - Youtube 동영상 다운로드 (YoutubeExplode 패키지) [1]파일 다운로드1
14020정성태10/2/20253528Linux: 125. eBPF - __attribute__((preserve_access_index)) 활용 사례
14019정성태10/1/20253861Linux: 124. eBPF - __sk_buff / sk_buff 구조체
14018정성태9/30/20252894닷넷: 2366. C# - UIAutomationClient를 이용해 시스템 트레이의 아이콘을 열거하는 방법파일 다운로드1
14017정성태9/29/20253390Linux: 123. eBPF (bpf2go) - BPF_PROG_TYPE_SOCKET_FILTER 예제 - SEC("socket")
14016정성태9/28/20253926Linux: 122. eBPF - __attribute__((preserve_access_index)) 사용법
14015정성태9/22/20253018닷넷: 2365. C# - FFMpegCore를 이용한 MP4 동영상으로부터 MP3 음원 추출 예제파일 다운로드1
14014정성태9/17/20253266닷넷: 2364. C# - stun.l.google.com을 사용해 공용 IP 주소와 포트를 알아내는 방법파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...