Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

C# 7 새로운 문법(1) - 더욱 편리해진 Out 변수 사용

이 글은 다음의 글에 대한 간략 번역서입니다.

New Features in C# 7.0
; https://blogs.msdn.microsoft.com/dotnet/2017/03/09/new-features-in-c-7-0/




out 인자를 사용하는 흔한 예제가 바로 int.TryParse인데요. C# 6.0 이전에는 TryParse의 2번째 인자에 넣을 변수를 반드시 미리 선언해 주어야 했습니다.

{
    int result; // 이렇게 변수를 미리 선언
    int.TryParse("5", out result);
}

이게 은근히 타이핑하기 귀찮은 면이 있었는데요, C# 7부터는 다음과 같이 간편하게 작성하는 것이 허용됩니다.

{
    int.TryParse("5", out int result);
}

==> 컴파일하면 다음의 코드로 변환

{
    int result;
    int.TryParse("5", out int result);
}

변환 코드에서도 나오지만 이때의 result 변수가 선언되는 변수 범위는 해당 코드를 감싸고 있는 첫 번째 {, } 중괄호가 됩니다. 따라서, 다음과 같은 코드는 result 변수의 중복 선언이 되기 때문에 컴파일 오류가 발생합니다.

{
    int.TryParse("5", out int result);
    int.TryParse("5", out int result); // 컴파일 오류!
}

==> 컴파일하면 다음의 코드로 변환

{
    int result;
    int.TryParse("5", out result);

    int result; // 중복 변수로 인해 컴파일 오류 발생
    int.TryParse("5", out result);
}

굳이 변수 명을 그대로 쓰고 싶다면 이런 식으로 작성해야 합니다.

{
    {
        int.TryParse("5", out int result);
    }

    {
        int.TryParse("5", out int result);
    }
}

==> 컴파일하면 다음의 코드로 변환

{
    {
        int result;
        int.TryParse("5", out result);
    }

    {
        int result;
        int.TryParse("5", out result);
    }
}


재미있는 것은, var 예약어의 사용이 여기서도 가능하다는 점입니다.

{
    int.TryParse("5", out var result);
}

어차피 컴파일러 입장에서는 해당 메서드(위의 예제에서는 TryParse)의 signature를 알고 있기 때문에 두 번째 인자에 대한 형식을 추론할 수 있습니다.

심지어, 값을 무시하는 구문까지 지원을 합니다.

{
    int.TryParse("5", out _); // out 인자에 담긴 값이 필요 없음.

    int.TryParse("5", out int _); // 타입명까지 지정해도 컴파일이 잘 됩니다.
    int.TryParse("5", out var _);
}

위와 같이 변수명이 있을 자리를 밑줄(_)로 처리하면 되는데, 저런 경우 값을 받을 수는 없지만 의도적으로 그럴 필요가 간혹 있긴 하므로 쓸만할 것입니다.

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




그런데, out 하면 생각나는 것이 ref 예약어입니다. 아쉽지만/당연하게도! 이번 축약 구문에서 ref는 혜택을 받지 못합니다.

int.TryParse("5", ref int result); // 예외 발생
                                // CS1525: Invalid expression term 'int'
                                // CS1003: Syntax error, ',' expected
                                // CS0103: The name 'result' does not exist in the current context

그도 그럴 것이, ref로 전달하는 인자는 반드시 호출하는 측에서 명시적으로 값을 할당해야 하기 때문입니다. 그래도 역시나 아쉬운 면이 있습니다. 다음과 같은 식으로 구현할 수 있게 만들어줬어도 됐을 텐데... ^^

int.TryParse("5", ref int result = 0); // 예외 발생




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







[최초 등록일: ]
[최종 수정일: 4/7/2017]

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  [43]  44  45  ...
NoWriterDateCnt.TitleFile(s)
12553정성태3/5/20219209개발 환경 구성: 548. 기존 .NET Framework 프로젝트를 .NET Core/5+ 용으로 변환해 주는 upgrade-assistant, try-convert 도구 소개 [4]
12552정성태3/5/20218474개발 환경 구성: 547. github workflow/actions에서 Visual Studio Marketplace 패키지 등록하는 방법
12551정성태3/5/20217388오류 유형: 702. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly. (2)
12550정성태3/5/20217063오류 유형: 701. Live Share 1.0.3713.0 버전을 1.0.3884.0으로 업데이트 이후 ContactServiceModelPackage 오류 발생하는 문제
12549정성태3/4/20217548오류 유형: 700. VsixPublisher를 이용한 등록 시 다양한 오류 유형 해결책
12548정성태3/4/20218320개발 환경 구성: 546. github workflow/actions에서 nuget 패키지 등록하는 방법
12547정성태3/3/20218859오류 유형: 699. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly.
12546정성태3/3/20218451개발 환경 구성: 545. github workflow/actions에서 빌드시 snk 파일 다루는 방법 - Encrypted secrets
12545정성태3/2/202111209.NET Framework: 1026. 닷넷 5에 추가된 POH (Pinned Object Heap) [10]
12544정성태2/26/202111429.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/20219770VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202112108개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/20219338개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/20219659.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
12539정성태2/16/20219567Windows: 189. WM_TIMER의 동작 방식 개요파일 다운로드1
12538정성태2/15/20219948.NET Framework: 1023. C# - GC 힙이 아닌 Native 힙에 인스턴스 생성 - 0SuperComicLib.LowLevel 라이브러리 소개 [2]
12537정성태2/11/202110977.NET Framework: 1022. UI 요소의 접근은 반드시 그 UI를 만든 스레드에서! - 두 번째 이야기 [2]
12536정성태2/9/20219978개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/20219091개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/20219735개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/20219357개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/20219872개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/20218834개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202112987개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202110111개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/20219496개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
... 31  32  33  34  35  36  37  38  39  40  41  42  [43]  44  45  ...