Microsoft MVP성태의 닷넷 이야기
The JIT does dead-code elimination in Debuggable code [링크 복사], [링크+제목 복사],
조회: 8629
글쓴 사람
정성태 (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)
1001정성태12/31/200810191.NET : 95. 빌드된 어셈블리를 서명하는 방법 [1]
1000정성태12/29/200810281Code Contracts
999정성태12/17/200811193Visual C++ : 14. Visual Studio 2010 - MSBuild
998정성태12/16/200811999.NET 3.0 : 26. WPF - HostVisual?
997정성태12/10/200811869.NET : 94. Native C++ 클래스를 상속받는 C# 클래스 정의
996정성태12/9/200812259.NET : 93. Document Reflector [1]
995정성태12/1/200811832Visual C++ : 13. Detours 라이브러리
993정성태11/30/200811770.NET 3.0 : 25. C# Extension 의 좋은 활용 예 - 오피스 Interop API Extensions
992정성태11/30/200816860.NET : 92. Application.DoEvents 의 부작용
991정성태11/26/200813951.NET 4.0: 6. Thread Pool 개선
990정성태11/25/200811562개발 환경 구성: 124. Hyper-V 와 도메인 컨트롤러
989정성태11/21/200811054IIS : 24. IIS7 - Process and Thread Identity in ASP.NET
988정성태11/9/200811312.NET 4.0: 5. C# 4.0 새기능들(2008년10월CTP버젼)
987정성태11/5/200811598.NET 4.0: 4. What's New in the BCL in .NET 4.0 [2]
986정성태11/3/200810845.NET 4.0: 3. Dump 디버깅 지원
985정성태10/30/200810552.NET 4.0: 2. .NET 4.0 포스터
984정성태10/30/200810899.NET 4.0: 1. No PIA
983정성태10/29/200810842Visual C++ : 12. Visual C++ 10
982정성태10/29/200812212.NET : 91. WPF Toolkit
981정성태10/27/200811256.NET : 90. Microsoft Chart control for .NET Framework
980정성태10/24/200811079Debug : 38. StackOverflow Notifier
979정성태10/24/200810674SDK : 15. ESENT (Extensible Storage Engine) API in the Windows SDK
978정성태10/23/200810968TFS : 170. TeamReview 도구
977정성태10/15/200813056.NET : 89. DotNetZip - ZIP 압축을 위한 닷넷 라이브러리
976정성태10/15/200810757TFS : 169. tf.exe 명령어 - workspaces /remove 와 workspaces /delete 의 차이
975정성태10/9/200810678.NET : 88. ClickOnce에서 .application 파일을 다운로드 하려고 할 때.
1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...