Microsoft MVP성태의 닷넷 이야기
The JIT does dead-code elimination in Debuggable code [링크 복사], [링크+제목 복사],
조회: 8628
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

출처: http://blogs.msdn.com/jmstall/archive/2006/03/13/dead_code_elimination.aspx

The JIT does dead-code elimination in Debuggable code

The desktop CLR JIT (at least x86) does dead-code elimination, even in debuggable code. This is obviously perfectly safe, transparent, (and good), from a program-execution perspective. But it can be a little surprising under the debugger because you can't set-next-statement (setip) to eliminated code.

In other words, if you have this C# code:
    Console.WriteLine("Hi!");
    if (false) {
        Console.WriteLine("Boo!"); // <-- can't setip here
    }
    Console.WriteLine("Bye");

You couldn't Set-next-statement to the "Boo!" line.  Normally this is fine, but every now and then it gets me. I think code-generators are more likely to produce code like that than a real person.

However, the JIT will not remove side-effect free expressions in debuggable code. For example,
    void Foo() {
        int x = 5;
        x ++;
    }

The JIT will not remove either of those lines, even though 'x' is unused and so they don't actually do anything for program behavior. This means you can still set and hit breakpoints on those lines, which is what you'd expect from debuggable (non-optimized) code.

In optimized-code, anything's fair game and a function like Foo() would very likely be optimized out of existence.

Published Monday, March 13, 2006 5:44 PM by jmstall

Comment Notification

If you would like to receive an email when updates are made to this post, please register here

You can also stay up to date using your favorite aggregator by subscribing to the CommentRss Feed








[최초 등록일: ]
[최종 수정일: 4/14/2006]


비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
1129정성태2/14/201114646.NET : 113. Running .NET applications in-process using AppDomains
1128정성태2/13/201115255개발 환경 구성: 143. Visual Studio 소스 서버 보안 경고창 없애기
1127정성태2/5/201114539개발 환경 구성: 142. Internet Explorer 6, 7, 8, 9 테스트 - 다중 XP Mode
1126정성태1/28/201120178개발 환경 구성: 141. 키보드 매핑을 바꾸는 레지스트리 설정파일 다운로드1
1125정성태12/24/201013515VS.NET IDE : 59. Visual Studio 2010 - 웹 프로젝트의 Web.debug.config / Web.Release.config 기능을 일반 프로젝트에 적용하는 방법
1124정성태11/16/201022224개발 환경 구성: 140. 대용량 파일 고속 전송: Rapidant
1123정성태11/11/201012181Web : 8. IE 9 플랫폼 프리뷰 6 + IE 9 베타
1122정성태11/9/201012722개발 환경 구성: 139. RemoteFX - USB Rediection
1121정성태11/6/201011653.NET : 112. The F# PowerPack, with F# Compiler Source Drops
1120정성태10/20/201013233Web : 7. Internet Explorer - Browser Mode 와 Document Mode
1119정성태10/9/201012381IIS : 32. Steps for setting up a custom identity of an IIS 6 application pool
1118정성태9/17/201011091Web : 6. Internet Explorer 9 Beta Guide for Developers
1117정성태8/25/201011570.NET : 111. Azure CDN Guide Available
1116정성태8/24/201011320Web : 5. IE 9 - UI 보더 변경에 따른 2-pixel 변화
1115정성태6/18/201013114개발 환경 구성: 138. 프로세스 덤프를 하는 다양한 방법
1114정성태6/1/201011489.NET : 110. C#5 and Meta-Programming [1]
1113정성태4/27/201012336VS.NET IDE : 58. Visual Studio 2010에 기본 내장된 WPF Tree Visualizer
1112정성태4/15/201012095개발 환경 구성: 137. How to enable remote connections in SQL Server 2008?
1111정성태4/2/201010473VS.NET IDE : 57. Simulating Peak Load with VS Load Tests
1110정성태3/30/201011417Windows 7: 4. Windows 7 / R2부터 제공되는 NT 서비스 전용 계정
1109정성태3/17/201012181개발 환경 구성: 136. SCVMM에서 VM을 Template로 만들어서 Library에 넣은 후 새로운 VM 배포하기
1107정성태3/1/201011744.NET : 109. .NET 4.0에서 obsolete로 처리되는 타입
1106정성태2/24/201012355IIS : 31. Microsoft Application Request Routing (ARR)과 TFS App Tier
1105정성태2/9/201011484Debug : 46. 프로세스 종료 시 덤프 남기는 방법
1104정성태1/26/201011639Debug : 45. Debugging References with Graph Visualizations
1103정성태11/18/200910733개발 환경 구성: 135. How to Configure WPL v1.0 SRE
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...