Microsoft MVP성태의 닷넷 이야기
++ 후위연산자와 = 을 함께 사용할 때 생성되는 IL 코드 관련... [링크 복사], [링크+제목 복사]
조회: 11685
글쓴 사람
Beren Ko (beren at live.co.kr)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요 성태님,

누군가가 질문을 해서 답변을 하다 IL을 살펴보니 이해가 가지 않는 부분이 있어 글을 써 봅니다.
컴파일러 구현하신 분에게나 여쭤봐야 하지 않을까 생각도 되지만 그냥 의외의 상황이기도 해서요.

일단 LINQPAD에 아래와 같이 코드를 작성하였습니다.

void Main()
{
    int testValue = 0;
    testValue = testValue ++;
    Console.WriteLine(testValue);
}

결과는 0으로 나오죠.
그 결과 까지는 납득이 가는데 IL 코드를 살펴보고 있으니 좀 이상한 코드를 생성하더라구요.

IL_0000: nop
IL_0001: ldc.i4.0
IL_0002: stloc.0 // testValue
IL_0003: ldloc.0 // testValue
IL_0004: stloc.1
IL_0005: ldloc.1
IL_0006: ldc.i4.1
IL_0007: add
IL_0008: stloc.0 // testValue
IL_0009: ldloc.1
IL_000A: stloc.0 // testValue
IL_000B: ldloc.0 // testValue
IL_000C: call System.Console.WriteLine
IL_0011: nop
IL_0012: ret

그냥 제가 해석한 바는
1. 상수 0을 스택에 불러오고 그 값을 0번 로컬 변수인 testValue 에 저장합니다.
2. 다시 0번 변수를 스택에 불러온 후 그 값을 1번 변수(아마도 임시 변수를 만드는 것 같네요)에 저장합니다. 현재까지 0번과 1번 변수 모두 0을 저장하고 있습니다.
3. 1번 로컬 변수를 스택에 불러온 후 상수 1도 스택에 불러옵니다.
4. 스택에 로드 된 0과 1을 더한 후 그 값을 0번 로컬 변수 testValue에 저장합니다. 이 시점에서 0번 변수는 1, 1번 변수는 0 입니다.
5. 0이 저장되어 있는 1번 변수 값을 다시 스택에 불러옵니다. 그 값을 1이 저장된 0번 변수에 저장합니다. 0, 1 변수 모두 0으로 됩니다.
6. 0 번 변수에 저장된 값(0) 을 불러온 후 Console.WriteLine 메서드를 호출 해 출력합니다.
7. 메서드 종료.

굳이 1번 변수를 만들어 내고 0번 변수에 값 1을 저장했다가 다시 1번 변수에 저장되어 있는 0을 덮어쓰는 이해할 수 없는 IL 코드에 잠깐 멍 해져선 쳐다보다가 글을 남겨봅니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 1/13/2017]


비밀번호

댓글 작성자
 



2017-01-13 03시56분
다음의 글로 정리해 봤습니다. 참고하세요. ^^

C# - IL 코드 분석을 위한 팁
; http://www.sysnet.pe.kr/2/0/11131
정성태
2017-01-13 06시29분
네...제가 완전 잘못된 관점으로 해석을 해서는 성태님도 글을 쓰시게 하고 원 질문자에게도 혼란을 준 것 같습니다.
반성하고 공부를 좀 해야하겠네요. 글 감사합니다^^
Beren Ko

... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...
NoWriterDateCnt.TitleFile(s)
5177농상6/13/20199579멀티스레드 건의 [2]
5176이선호6/13/20199170안녕하세요. 닷넷 문제로 검색하다 알게되어 들어왔습니다. 현재 IIS 문제가 있어 질문드립니다. [1]
5175Chobo6/12/20199154WPF Ellipse 그리기! [3]
5174농상6/11/20198499ThreadPool 조인에 관해 [1]
5173전우치6/9/20198935공유 리소스에 대한 스레드 동기화 처리를 위해서 lock 이용 시 문의 [3]
5172김대훈6/7/20197729너무힘드네요 공부에 대한조언부탁드립니다 [2]
5171조남석6/4/20197439EX)11-2(treeview)에 대한 질문입니다. [3]
5170레리6/4/20198041Setup 프로젝트 레지스트리 설정 관련 질문입니다. [1]파일 다운로드1
5169농상6/3/20197819멀티스레드 파라미터 관련 [2]
5168익명유저5/30/20197091항상 정말 감사드립니다... [1]
5167WPF5/23/20198017질문드립니다. [1]
5165이대희5/22/20197164Visual Studio 설치 구성요소 문의 (C# 7.3 개정판 관련) [1]
5164레드5/21/20198678실행 과정과 실행파일 디버그 시 Icon변경 질문드립니다. [5]
5163이대희5/20/20196974시작하세요 C# 7.3 프로그래밍 책 도착했습니다. [1]
5162채홍윤5/14/20199807Mono Develop window 설치 [6]
5161정대영5/13/20197729VS 2013에서 C#6.0(.netFramwork 4.6.1) $ 디버깅 오류 [1]
5160초보개발자5/13/20198714wcf 관련 국내 서적 살만한 책이 있나요? [2]
5159sdh25/9/20198220VS 2010 버전에서 생성한 DLL을 VS 2017버전에서 실행 시 에러 [2]
5158sdh5/8/20197131Visual studio 2010 버전에서 생성한 Project를 Visual studio 2017버전에서 실행에러 [1]
5157김경훈5/8/201910127Task 만들때 넘겨주는 CancellationToken은 어디서 사용 되는 건가요? [4]
5156rysoo5/8/20198396yield return의 리턴 타입 질문 드립니다. [4]
5155세퉁5/7/201910291관리자 권한으로 실행 시 알림창(?) 없이 바로 실행 시킬 수 있는 방법이 있을까요?? [2]파일 다운로드1
5154Soul...5/4/20197177NamedPipe 질문드립니다. [2]
5153개태5/4/20198142WCF RESTful Service에서 enum을 parameter로 쓰는방법 [2]
5152세퉁5/3/20199262인터넷 시간을 불러와 pc에 적용 시키고 싶습니다. [3]파일 다운로드1
5151이대희5/3/20197364C# 7.3으로 개정판 출간 계획이 있으신가요? [1]
... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...