Microsoft MVP성태의 닷넷 이야기
The JIT does dead-code elimination in Debuggable code [링크 복사], [링크+제목 복사],
조회: 8682
글쓴 사람
정성태 (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]


비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
550정성태12/11/200610759Vista : 17. 응용 프로그램 복구 및 재시작 시 콜백 함수 등록
549정성태12/2/20069912TFS : 60. Orcas 에서 제공되는 Team Build 관련 기능들
548정성태12/1/200610074.NET : 39. .NET 2.0 에는 더 이상 mscorsvr.dll 이 없습니다.
547정성태12/1/20069287개발 환경 구성: 60. 비스타 단축키 정보
546정성태12/1/200610457TFS : 59. Teamprise 2.0 릴리스 [1]
545정성태12/1/200610108개발 환경 구성: 59. Crash 로 인한 Dump(*.dmp) 파일을 구하는 방법
544정성태12/1/200610502Vista : 16. 비스타에 구현된 UIPI 기능이란?
543정성태12/1/20069675.NET : 38. App Config 파일에 Generic 클래스 명시하는 방법
542정성태11/30/20069825.NET : 37. CSS Friendly Adapters 소식
541정성태11/28/20069579TFS : 58. TFS Permission Manager 1.0
540정성태11/28/200610075개발 환경 구성: 58. Vista 에서 VS.NET 2005 웹 애플리케이션 개발시 유의할 점.
539정성태11/26/200610201.NET : 36. 상속받은 클래스에서 부모의 abstract 메서드 구현을 생략하는 방법 [2]
538정성태11/24/200610338Vista : 15. Ten Things to Try: Windows Vista
537정성태11/23/200610393.NET 3.0 : 9. WPF, WCF, WWF, CardSpace 의 상호 연동
536정성태11/23/20069977.NET : 35. STL/CLR Spec 배포
535정성태11/22/200610931.NET : 34. C# 3.0 과 F#
534정성태11/21/200610352개발 환경 구성: 57. Anti-Cross Site Scripting Library v1.5
533정성태11/21/20069887TFS : 57. Work Item 을 프로젝트 간에 이동시켜 주는 도구
532정성태11/18/20069720x64 : 3. Enterprise Library for .NET Framework 2.0: Performance Comparison 64 Bit vs. 32 Bit
531정성태11/18/20069374개발 환경 구성: 56. 코드 스니핏 디자이너 (알파 버전)
530정성태11/17/20069223개발 환경 구성: 55. Data Access Virtual Labs
529정성태11/17/20069928.NET 3.0 : 8. WCF 를 이용한 런타임 바인딩
528정성태11/16/20069547VS.NET IDE : 14. Orcas - 다중 .NET 버전을 지원하는 빌드
527정성태11/16/20069922TFS : 56. MSF for Agile Software Development and MSF for CMMI Process Improvement Version 4.1 Available
526정성태11/16/20069412개발 환경 구성: 54. Visual Studio on Windows Vista
525정성태11/14/200610417Vista : 14. .NET 개발자들을 위한 Vista 기능 소개
... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...