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

C# 7.0에서도 부분적으로 가능해진 "타입 추론을 통한 튜플의 변수명 자동 지정"

C# 7.1 컴파일러부터 "타입 추론을 통한 튜플의 변수명 자동 지정"이 추가되었습니다.

Infer tuple names (aka. tuple projection initializers)
; https://github.com/dotnet/csharplang/blob/master/proposals/csharp-7.1/infer-tuple-names.md

제 책에서는 "13.3" 절에 그 내용을 설명하고 있는데요. 관련해서 책에 포함된 예제가 다음의 코드입니다.

int age = 20;
string name = "Kevin Arnold";

var person = (age, name);

Console.WriteLine($"{person.age}, {person.name}");

위의 코드를 C# 7.0 컴파일러에 맞춰놓고 빌드하면 다음과 같은 CS8306 컴파일 오류가 발생합니다.

1>------ Build started: Project: ConsoleApp2, Configuration: Debug Any CPU ------
1>D:\temp\ConsoleApp2\ConsoleApp2\Program.cs(18,41,18,44): error CS8306: Tuple element name 'age' is inferred. Please use language version 7.1 or greater to access an element by its inferred name.
1>D:\temp\ConsoleApp2\ConsoleApp2\Program.cs(18,55,18,59): error CS8306: Tuple element name 'name' is inferred. Please use language version 7.1 or greater to access an element by its inferred name.
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

오류 메시지에 보이듯이, 당연히 C# 7.1로 설정하고 빌드하면 정상적으로 컴파일이 됩니다.




그런데 우연히 보게 된 글에서,

Something Wrong In Csharp Tuple
C#의 튜플은 어디서부턴가 잘못되었다
; https://phillyai.github.io/2017-08-22-Something-Wrong-In-Csharp-Tuple/

재미있는 예제를 접했습니다.

using System;
using System.Linq;

namespace ConsoleApp2
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] list = { 3, 1, 4, 1, 5, 9, 2 };
            foreach (var (v, i) in list.Select((val, index) => (val, index)))
            {
                Console.WriteLine($"{i}: {v}");
            }
        }
    }
}

위의 예제 코드를 최근의 Visual Studio에서 C# 7.0을 대상으로 빌드하면 정상적으로 빌드가 됩니다. 그런데, 좀 오래된 Visual Studio, 확실하게 15.3.1 버전의 경우에는 C# 7.0을 대상으로 하면 다음과 같은 CS8306 컴파일 오류가 발생합니다.

1>------ Rebuild All started: Project: ConsoleApp2, Configuration: Debug Any CPU ------
1>D:\temp\ConsoleApp2\ConsoleApp2\Program.cs(14,13,17,14): error CS8306: Tuple element name 'val' is inferred. Please use language version 7.1 or greater to access an element by its inferred name.
1>D:\temp\ConsoleApp2\ConsoleApp2\Program.cs(14,13,17,14): error CS8306: Tuple element name 'index' is inferred. Please use language version 7.1 or greater to access an element by its inferred name.
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========

동일하게 "CS8306: Tuple element name '...' is inferred" 컴파일 오류인데, 최근의 C# 컴파일러에서는 7.0으로 맞춰놓고 해도 정상적으로 빌드가 되는 것입니다. 제 예상으로는, roslyn 컴파일러의 소스 코드를 7.1 이후에 수정을 하다가 C# 7.0 모드에서도 튜플에 대한 변수명이 추론이 되도록 하는 (좋은) 부작용이 발생한 것으로 보입니다.




일반적인 상황에서는 전혀 중요하지 않은 이야기인데... 혹시나 관련 소스 코드를 빌드하면서 C# 7.0에도 튜플 추론이 잘 된다고 메일을 보내실 독자분을 위해 미리 쉴드성 글을 남깁니다. ^^




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







[최초 등록일: ]
[최종 수정일: 5/11/2018]

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

비밀번호

댓글 작성자
 




... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13576정성태3/8/202411778닷넷: 2228. .NET Profiler - IMetaDataEmit2::DefineMethodSpec 사용법
13575정성태3/7/202412464닷넷: 2227. 최신 C# 문법을 .NET Framework 프로젝트에 쓸 수 있을까요?
13574정성태3/6/202411911닷넷: 2226. C# - "Docker Desktop for Windows" Container 환경에서의 IPv6 DualMode 소켓
13573정성태3/5/202410508닷넷: 2225. Windbg - dumasync로 분석하는 async/await 호출
13572정성태3/4/202410388닷넷: 2224. C# - WPF의 Dispatcher Queue로 알아보는 await 호출의 hang 현상파일 다운로드1
13571정성태3/1/202410365닷넷: 2223. C# - await 호출과 WPF의 Dispatcher Queue 동작 확인파일 다운로드1
13570정성태2/29/202411587닷넷: 2222. C# - WPF의 Dispatcher Queue 동작 확인파일 다운로드1
13569정성태2/28/202411348닷넷: 2221. C# - LoadContext, LoadFromContext 그리고 GAC파일 다운로드1
13568정성태2/27/202411176닷넷: 2220. C# - .NET Framework 프로세스의 LoaderOptimization 설정을 확인하는 방법파일 다운로드1
13567정성태2/27/202411097오류 유형: 898. .NET Framework 3.5 이하에서 mscoree.tlb 참조 시 System.BadImageFormatException파일 다운로드1
13566정성태2/27/202411056오류 유형: 897. Windows 7 SDK 설치 시 ".NET Development" 옵션이 비활성으로 선택이 안 되는 경우
13565정성태2/23/20249527닷넷: 2219. .NET CLR2 보안 모델에서의 개별 System.Security.Permissions 제어
13564정성태2/22/202411606Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
13563정성태2/21/202410988디버깅 기술: 196. windbg - async/await 비동기인 경우 메모리 덤프 분석의 어려움
13562정성태2/21/202410230오류 유형: 896. ASP.NET - .NET Framework 기본 예제에서 System.Web에 대한 System.IO.FileNotFoundException 예외 발생
13561정성태2/20/202411370닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/202411413디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/202412536오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/202411642닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20249781Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/202410900Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/202411030닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/202410333VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20249451닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20249634닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/202411097닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...