Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 1. VC++ 프로파일링 사용법 [링크 복사], [링크+제목 복사],
조회: 23436
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 136  137  138  [139]  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1579정성태1/12/201422241오류 유형: 207. System.ArgumentException was unhandled - Message=[net_WebHeaderInvalidControlChars]
1578정성태1/11/201433754개발 환경 구성: 209. Fiddler에서 WebSocket 통신을 모니터링하는 방법 [1]
1577정성태1/11/201423967오류 유형: 206. WriteFile Win32API 사용 시 비정상 종료 현상 [3]
1576정성태1/11/201441920Windows: 81. 긴 이름의 파일/폴더 삭제하는 법 [5]
1575정성태1/11/201422367오류 유형: 205. Exception calling "Provision" with "0" argument(s): "The timer job did not complete running within the allotted time."
1574정성태1/11/201424365오류 유형: 204. An unhandled exception ('System.Security.Cryptography.CryptographicException') occurred in OWSTIMER.EXE
1573정성태1/11/201422158오류 유형: 203. 이벤트 로그 에러 - MsiInstaller에서 Chart Controls 설치 관련 오류 발생
1572정성태1/9/201425675.NET Framework: 406. CoreLab - OraDirect .NET 사용법
1571정성태1/9/201421853.NET Framework: 405. override 메서드가 정의된 타입의 인스턴스로 base 메서드를 호출하는 방법 - 두 번째 이야기
1570정성태1/9/201425268Math: 11. C# 시뮬레이션 - 몬티홀 게임파일 다운로드1
1569정성태1/8/201422490Windows: 80. 윈도우 서버 백업의 복원하는 옵션 설명
1568정성태1/8/201423037오류 유형: 202. Hyper-V 서비스 시작 오류 - Not enough storage is available to complete this operation.
1567정성태1/8/201492407기타: 40. 오피스 2013 라이선스 리셋하는 방법 [5]
1566정성태1/7/201423390Windows: 79. 윈도우 8 - 스카이드라이브(skydrive)의 Online/Offline 동기화 방식 [1]
1565정성태1/3/201421860.NET Framework: 404. 리플렉션을 이용해 닷넷 LicenseManager를 우회할 수 있는 사례
1564정성태1/3/201422376.NET Framework: 403. override 메서드가 정의된 타입의 인스턴스로 base 메서드를 호출하는 방법파일 다운로드1
1563정성태1/3/201428081오류 유형: 201. ASP.NET 웹 사이트를 IIS 7 이상의 환경에서 호스팅할 때 500 오류 발생
1562정성태1/2/201432748.NET Framework: 402. 카카오톡 PC 버전 실행 시 개발자 컴퓨터에서 Themida 오류 나는 문제 - 두 번째 이야기
1561정성태1/1/201442277오류 유형: 200. 카카오톡 PC 버전 실행 시 개발자 컴퓨터에서 Themida 오류 나는 문제 [2]
1560정성태1/1/201421049오류 유형: 199. Hyper-V - Checkpoint 생성 오류
1559정성태12/30/201324316.NET Framework: 401. windbg에서 확인해 보는 관리 힙의 인스턴스 구조 [2]
1558정성태12/29/201333755.NET Framework: 400. 눈으로 확인하는 LayoutKind 옵션 효과 [2]파일 다운로드1
1557정성태12/27/201322784.NET Framework: 399. LayoutKind 옵션에 대해 [2]
1556정성태12/27/201343109개발 환경 구성: 208. IIS + Node.js 환경 구성 [8]
1555정성태12/27/201329871개발 환경 구성: 207. IIS의 80 포트를 공유하는 응용 프로그램 만드는 방법 [1]
1554정성태12/26/201335255Windows: 78. 마음에 드는 윈도우 8.1 태블릿 - 델 베뉴 8 프로 5830 [4]
... 136  137  138  [139]  140  141  142  143  144  145  146  147  148  149  150  ...