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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  [103]  104  105  ...
NoWriterDateCnt.TitleFile(s)
11449정성태1/23/201825529오류 유형: 449. 단위 테스트 - Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies. [1]
11448정성태1/20/201823764오류 유형: 448. Fakes를 포함한 단위 테스트 프로젝트를 빌드 시 CS0619 관련 오류 발생
11447정성태1/20/201825122.NET Framework: 730. dotnet user-secrets 명령어 [2]파일 다운로드1
11446정성태1/20/201824865.NET Framework: 729. windbg로 살펴보는 GC heap의 Segment 구조 [2]파일 다운로드1
11445정성태1/20/201823029.NET Framework: 728. windbg - 눈으로 확인하는 Workstation GC / Server GC
11444정성태1/19/201822734VS.NET IDE: 125. Visual Studio에서 Selenium WebDriver를 이용한 웹 브라우저 단위 테스트 구성파일 다운로드1
11443정성태1/18/201825286VC++: 124. libuv 모듈 살펴 보기
11442정성태1/18/201821135개발 환경 구성: 353. ASP.NET Core 프로젝트의 "Enable unmanaged code debugging" 옵션 켜는 방법
11441정성태1/18/201819167오류 유형: 447. ASP.NET Core 배포 오류 - Ensure that restore has run and that you have included '...' in the TargetFrameworks for your project.
11440정성태1/17/201822633.NET Framework: 727. ASP.NET의 HttpContext.Current 구현에 대응하는 ASP.NET Core의 IHttpContextAccessor/HttpContextAccessor 사용법파일 다운로드1
11439정성태1/17/201829051기타: 69. C# - CPU 100% 부하 주는 프로그램파일 다운로드1
11438정성태1/17/201822097오류 유형: 446. Error CS0234 The type or namespace name 'ITuple' does not exist in the namespace
11437정성태1/17/201821950VS.NET IDE: 124. Platform Toolset 설정에 따른 Visual C++의 헤더 파일 기본 디렉터리
11436정성태1/16/201824504개발 환경 구성: 352. ASP.NET Core (EXE) 프로세스가 IIS에서 호스팅되는 방법 - ASP.NET Core Module(AspNetCoreModule) [4]
11435정성태1/16/201826110개발 환경 구성: 351. OWIN 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)파일 다운로드2
11434정성태1/15/201827412개발 환경 구성: 350. 사용자 정의 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)파일 다운로드2
11433정성태1/15/201825201개발 환경 구성: 349. dotnet ef 명령어 사용을 위한 준비
11432정성태1/11/201832760.NET Framework: 726. WPF + Direct2D + SharpDX 출력 C# 예제파일 다운로드2
11431정성태1/11/201828359.NET Framework: 725. C# - 동기 방식이면서 비동기 메서드(awaitable)처럼 구현한 사례 [9]
11430정성태1/10/201831700.NET Framework: 724. WPF + Direct2D 출력 C# 예제 [2]파일 다운로드1
11429정성태1/9/201821874개발 환경 구성: 348. ASP.NET Core 2.1 Preview 버전 적용 방법
11428정성태1/6/201825766개발 환경 구성: 347. WinForm 프로젝트를 WPF 프로젝트 유형으로 변경하는 방법파일 다운로드1
11427정성태1/5/201822415오류 유형: 445. vcpkg 빌드 오류 - Starting the CLR failed with HRESULT 80040153
11426정성태1/5/201833576오류 유형: 444. curl로 호출할 때 발생하는 오류 정리
11425정성태1/4/201824189개발 환경 구성: 346. ASP.NET Core Web Application을 IIS에서 호스팅하는 방법 (2)
11424정성태1/4/201823407개발 환경 구성: 345. ASP.NET Core 프로젝트를 명령행에서 빌드하는 방법
... 91  92  93  94  95  96  97  98  99  100  101  102  [103]  104  105  ...