Microsoft MVP성태의 닷넷 이야기
The JIT does dead-code elimination in Debuggable code [링크 복사], [링크+제목 복사]
조회: 8569
글쓴 사람
정성태 (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)
1178정성태11/2/20222673개발 환경 구성: 153. 10기가비트 홈 네트워크 구축하기
1177정성태11/12/20213907.NET : 131. RIP Copy and Paste from Stackoverflow! (+Trojan Source Solution)
1176정성태8/6/20217000.NET : 130. Developing a realtime full stack app with .NET, Angular, and MongoDB
1175정성태5/24/20214736.NET : 129. Create a colored CLI with System.CommandLine and Spectre
1174정성태10/16/20205376Debug : 53. Debugging services startup in Svchost from a kernel mode debug session
1173정성태9/11/20205549Windows 7: 5. Group Policy Administrative Templates Catalog [1]
1172정성태9/8/20205607.NET : 128. How to Write a Terminal Services Add-in in Pure C#
1171정성태10/10/20198159개발 환경 구성: 152. 비주얼 스튜디오를 인터넷 연결이 안 되는 환경에서 설치하는 방법
1170정성태8/8/20197662개발 환경 구성: 151. [DevOps] Slack에서 Visual Studio Team Service 빌드 결과 알림 받기
1169정성태10/15/20189784.NET : 127. Open-source library guidance
1168정성태7/13/201711679.NET : 126. The UWP Community Toolkit is 1 1/2! (v1.5) [2]
1167정성태6/27/201711428VS.NET IDE : 62. Visual Studio 2017의 디버깅 팁 7가지
1166정성태10/1/201511968.NET : 125. Building a large text file editor [1]파일 다운로드1
1165정성태8/20/201512208개발 환경 구성: 150. Windows Time Synchronization The Battle Continues
1164정성태4/3/201513651개발 환경 구성: 149. IE 개발자 도구와 같은 기능을 제공하는 오픈 소스 도구 - IE Diagnostics Adapter
1163정성태2/20/201515125Debug : 52. DbMon.NET - A simple .NET OutputDebugString capturer
1162정성태1/15/201415907Debug : 51. Psscor2 / Psscor4
1161정성태1/11/201320036개발 환경 구성: 148. 관리자 권한의 cmd.exe 단축아이콘 실행할 때 시작 폴더 지정
1160정성태1/3/201318586마이크로소프트 개발 플랫폼 총정리
1159정성태9/12/201217807Debug : 50. "DbgHost Type Library"를 이용한 .NET 내부 정보 열람
1158정성태4/4/201218451개발 환경 구성: 147. Microsoft Store를 거치지 않고 LOB 프로그램을 배포하는 방법
1157정성태3/30/201218887.NET : 124. 자바의 File.canWrite 메서드의 C# 버전
1156정성태2/9/201218474.NET : 123. .NET 4.5에서 Workflow Foundation 3을 deprecated 처리
1155정성태2/6/201218550Visual C++ : 19. Parallel Programming, OpenMP 그리고 Win32파일 다운로드1
1154정성태1/16/201219957.NET : 122. msiexec.exe를 닷넷으로 만들어 보면!파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...