Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# 컴파일러가 허용하지 않는 (유효한) 코드를 컴파일해 테스트하는 방법

아래의 질문이 있군요.

시작하세요 C# 7.1 프로그래밍 P53쪽 질문입니다.
; https://www.sysnet.pe.kr/3/0/5001

예전에 써 둔 글 중의 하나가 이와 관련해 답변이 될 듯 한데요.

C# 컴파일러는 변수를 초기화시키지 않을까요?
; https://www.sysnet.pe.kr/2/0/1651

그래도 다시 한번 간략하게 정리해 보겠습니다. ^^




그러니까 다음의 코드가 있는데,

using System;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            string text1;
            string text2 = null;

            Console.WriteLine(text1); // 컴파일 에러 - Error CS0165 Use of unassigned local variable 'text1'
            Console.WriteLine(text2);
        }
    }
}

사실 상, text1 변수와 text2 변수는 동일한 (null) 값을 가지고 있음에도 불구하고 text1의 경우 "사용자가 명시적으로 할당하지 않은" 상태로 사용하고 있기 때문에 C# 컴파일러는 컴파일 에러를 내버리는 것입니다.

만약, 저 코드를 그래도 실행해 보고 싶다면 어떻게 해야 할까요? 바로 IL 코드로 바꿔주면 됩니다. 이를 위해 일단, Console.WriteLine(text1); 코드를 주석 처리하고 빌드해 줍니다. 그렇게 나온 exe 파일을 ildasm.exe를 이용해 역어셈블합니다.

ildasm /out=test.il ConsoleApp1.exe

출력된 test.il 파일을 열어 Main 메서드의 구현을 보면 다음과 같이 되어 있습니다.

.class private auto ansi beforefieldinit ConsoleApp1.Program
       extends [mscorlib]System.Object
{
  .method private hidebysig static void  Main(string[] args) cil managed
  {
    .entrypoint
    // Code size       11 (0xb)
    .maxstack  1
    .locals init ([0] string text1,
             [1] string text2)
    IL_0000:  nop
    IL_0001:  ldnull
    IL_0002:  stloc.1
    IL_0003:  ldloc.1
    IL_0004:  call       void [mscorlib]System.Console::WriteLine(string)
    IL_0009:  nop
    IL_000a:  ret
  } // end of method Program::Main}

따라서, IL 문법에 맞춰 string text1 변수의 값을 다음과 같이 출력하도록 바꿔주고,

  .method private hidebysig static void  Main(string[] args) cil managed
  {
    .entrypoint
    // Code size       11 (0xb)
    .maxstack  1
    .locals init ([0] string text1,
             [1] string text2)
    IL_0000:  nop
    IL_0001:  ldnull
    IL_0002:  stloc.1

    IL_1000:  ldloc.0   
    IL_1001:  call void [mscorlib]System.Console::WriteLine(string)

    IL_0003:  ldloc.1
    IL_0004:  call       void [mscorlib]System.Console::WriteLine(string)
    IL_0009:  nop
    IL_000a:  ret
  } // end of method Program::Main

다시 ilasm.exe를 이용해 빌드하면 됩니다.

ilasm test.il /out=test.exe

그렇게 생성된 test.exe를 실행하면 다음과 같이 2번의 개행이 되어 출력되는 것을 볼 수 있습니다.

C:\ConsoleApp1\bin\Debug>test



C:\ConsoleApp1\bin\Debug>




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/2/2018]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12299정성태8/27/202020236.NET Framework: 934. C# - ETW 관련 Win32 API 사용 예제 코드 (3) ETW Consumer 구현파일 다운로드1
12298정성태8/27/202020074오류 유형: 640. livekd - Could not resolve symbols for ntoskrnl.exe: MmPfnDatabase
12297정성태8/25/202019552개발 환경 구성: 503. SHA256 테스트 인증서 생성 방법
12296정성태8/24/202020619.NET Framework: 933. C# - ETW 관련 Win32 API 사용 예제 코드 (2) NT Kernel Logger파일 다운로드1
12295정성태8/24/202019347오류 유형: 639. Bitvise - Address is already in use; bind() in ListeningSocket::StartListening() failed: Windows error 10013: An attempt was made to access a socket ,,,
12293정성태8/24/202020380Windows: 171. "Administered port exclusions" 설명
12292정성태8/20/202023729.NET Framework: 932. C# - ETW 관련 Win32 API 사용 예제 코드 (1)파일 다운로드2
12291정성태8/15/202020223오류 유형: 638. error 1297: Device driver does not install on any devices, use primitive driver if this is intended.
12290정성태8/11/202021545.NET Framework: 931. C# - IP 주소에 따른 국가별 위치 확인 [8]파일 다운로드1
12289정성태8/6/202018519개발 환경 구성: 502. Portainer에 윈도우 컨테이너를 등록하는 방법
12288정성태8/5/202016751오류 유형: 637. WCF - The protocol 'net.tcp' does not have an implementation of HostedTransportConfiguration type registered.
12287정성태8/5/202019097오류 유형: 636. C# - libdl.so를 DllImport로 연결 시 docker container 내에서 System.DllNotFoundException 예외 발생
12286정성태8/5/202020555개발 환경 구성: 501. .NET Core 용 container 이미지 만들 때 unzip이 필요한 경우
12285정성태8/4/202019439오류 유형: 635. 윈도우 10 업데이트 - 0xc1900209 [2]
12284정성태8/4/202018867디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법
12283정성태8/3/202020578디버깅 기술: 168. windbg - 필터 드라이버 확인하는 확장 명령어(!fltkd) [2]
12282정성태8/2/202017618디버깅 기술: 167. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash (2)
12281정성태8/2/202021748개발 환경 구성: 500. (PDB 연결이 없는) DLL의 소스 코드 디버깅을 dotPeek 도구로 해결하는 방법
12280정성태8/2/202019264오류 유형: 634. 오라클 (평생) 무료 클라우드 VM 생성 후 SSH 접속 시 키 오류 발생 [2]
12279정성태7/29/202021798개발 환경 구성: 499. 닷넷에서 접근해보는 InterSystems의 Cache 데이터베이스파일 다운로드1
12278정성태7/23/202017801VS.NET IDE: 149. ("Binary was not built with debug information" 상태로) 소스 코드 디버깅이 안되는 경우
12277정성태7/23/202019957개발 환경 구성: 498. DEVPATH 환경 변수의 사용 예 - .NET Reflector의 (PDB 연결이 없는) DLL의 소스 코드 디버깅
12276정성태7/23/202019808.NET Framework: 930. 개발자를 위한 닷넷 어셈블리 바인딩 - DEVPATH 환경 변수
12275정성태7/22/202021553개발 환경 구성: 497. 닷넷에서 접근해보는 InterSystems의 IRIS Data Platform 데이터베이스파일 다운로드1
12274정성태7/21/202020599개발 환경 구성: 496. Azure - Blob Storage Account의 Location 이전 방법 [1]파일 다운로드1
12273정성태7/18/202023830개발 환경 구성: 495. Azure - Location이 다른 웹/DB 서버의 경우 발생하는 성능 하락
... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...