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

.NET Framework 프로젝트에서 C# 8.0/9.0 컴파일러를 사용하는 방법

현재 Visual Studio 2019에서는 모든 닷넷 프로젝트에 걸쳐서 기본적으로 C# 컴파일러의 버전을 바꾸지 못하도록 했습니다. 그래서 프로젝트 설정의 고급 빌드(Build / Advanced Build Settings)에 가보면 다음과 같은 식으로 링크가 제공되는데,

cs8_in_netfr_1.png

Automatically selected based on framework version
Why can't I select a different C# version?

누르면 아래의 문서로 넘어갑니다.

C# language versioning
; https://learn.microsoft.com/en-us/dotnet/csharp/language-reference/configure-language-version

정리해 보면, 생성한 닷넷 프로젝트의 환경에 따라 다음과 같이 C# 컴파일러 버전이 자동 적용된다고 합니다.

.NET 5 - C# 9.0
.NET Core 3.x - C# 8.0
.NET Core 2.x - C# 7.3

.NET Standard 2.1 - C# 8.0
.NET Standard 2.0 - C# 7.3
.NET Standard 1.x - C# 7.3
.NET Framework (all) - C# 7.3

.NET Framework의 마지막 버전이 4.8이고 그것이 .NET Standard 2.0을 구현하고 있기 때문에 결국 .NET Framework 환경에서는 8.0/9.0 버전의 컴파일러 적용이 안 되고 있는 것입니다.

실제로 .NET 4.8 대상으로 다음의 C# 8.0 (또는 9.0) 코드를 사용해 컴파일하면,

class Program
{
    static void Main(string[] args)
    {
        using var file = new System.IO.StreamReader("test.txt");
    }
}

컴파일 오류(CS8370)가 발생합니다.

CS8370 Feature 'using declarations' is not available in C# 7.3. Please use language version 8.0 or greater.




물론 방법은 있습니다. 문서(C# language versioning)에도 나오지만, 프로젝트 파일(csproj)을 직접 편집기로 열어 LangVersion 노드를 다음과 같이 명시적으로 추가해 주면 됩니다.

<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" ...[생략]... />
  <PropertyGroup>
    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
    <ProjectGuid>{4F3F253F-549E-42AD-B367-881973F0EEA4}</ProjectGuid>
    <OutputType>Exe</OutputType>
    <RootNamespace>ConsoleApp1</RootNamespace>
    <AssemblyName>ConsoleApp1</AssemblyName>
    <TargetFrameworkVersion>v4.8</TargetFrameworkVersion>
    <FileAlignment>512</FileAlignment>
    <AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
    <Deterministic>true</Deterministic>
    <LangVersion>9.0</LangVersion>
  </PropertyGroup>
    // ...[생략]...
</Project>

(LangVersion은 설정 시 바로 반영되지만, 간혹 Visual Studio를 재시작해야 되는 경우도 있습니다.)

이후, 다시 이 글의 예제 코드를 컴파일하면 정상적으로 빌드가 되는 것을 확인할 수 있습니다. 물론, 그래도 모든 C# 8.0/9.0의 구문을 사용할 수 있는 것은 아닙니다. 가령 비동기 스트림 구문의 경우,

Asynchronous streams
; https://learn.microsoft.com/en-us/dotnet/csharp/whats-new/csharp-8#asynchronous-streams

IAsyncEnumerable 타입을 사용해야 하는데,

public static async System.Collections.Generic.IAsyncEnumerable<int> GenerateSequence()
{
    for (int i = 0; i < 20; i++)
    {
        await Task.Delay(100);
        yield return i;
    }
}

이것이 기본 .NET Frmaework 4.8에는 포함되어 있지 않으므로 컴파일 오류가 발생합니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/13/2024]

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)
13162정성태11/15/202215712.NET Framework: 2069. .NET 7 - AOT(ahead-of-time) 컴파일 [1]
13161정성태11/14/202214366.NET Framework: 2068. C# - PublishSingleFile로 배포한 이미지의 역어셈블 가능 여부 (난독화 필요성) [4]
13160정성태11/11/202214326.NET Framework: 2067. C# - PublishSingleFile 적용 시 native/managed 모듈 통합 옵션
13159정성태11/10/202217647.NET Framework: 2066. C# - PublishSingleFile과 관련된 옵션 [3]
13158정성태11/9/202213333오류 유형: 826. Workload definition 'wasm-tools' in manifest 'microsoft.net.workload.mono.toolchain' [...] conflicts with manifest 'microsoft.net.workload.mono.toolchain.net7'
13157정성태11/8/202214367.NET Framework: 2065. C# - Mutex의 비동기 버전파일 다운로드1
13156정성태11/7/202215964.NET Framework: 2064. C# - Mutex와 Semaphore/SemaphoreSlim 차이점파일 다운로드1
13155정성태11/4/202214208디버깅 기술: 183. TCP 동시 접속 (연결이 아닌) 시도를 1개로 제한한 서버
13154정성태11/3/202214691.NET Framework: 2063. .NET 5+부터 지원되는 GC.GetGCMemoryInfo파일 다운로드1
13153정성태11/2/202216010.NET Framework: 2062. C# - 코드로 재현하는 소켓 상태(SYN_SENT, SYN_RECV)
13152정성태11/1/202214907.NET Framework: 2061. ASP.NET Core - DI로 추가한 클래스의 초기화 방법 [1]
13151정성태10/31/202214355C/C++: 161. Windows 11 환경에서 raw socket 테스트하는 방법파일 다운로드1
13150정성태10/30/202213257C/C++: 160. Visual Studio 2022로 빌드한 C++ 프로그램을 위한 다른 PC에서 실행하는 방법
13149정성태10/27/202213830오류 유형: 825. C# - CLR ETW 이벤트 수신이 GCHeapStats_V1/V2에 대해 안 되는 문제파일 다운로드1
13148정성태10/26/202213753오류 유형: 824. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFramew
13147정성태10/25/202213029오류 유형: 823. Visual Studio 2022 - Unable to attach to CoreCLR. The debugger's protocol is incompatible with the debuggee.
13146정성태10/24/202214335.NET Framework: 2060. C# - Java의 Xmx와 유사한 힙 메모리 최댓값 제어 옵션 HeapHardLimit
13145정성태10/21/202214970오류 유형: 822. db2 - Password validation for user db2inst1 failed with rc = -2146500508
13144정성태10/20/202214661.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법파일 다운로드1
13143정성태10/19/202215603오류 유형: 821. windbg/sos - Error code - 0x000021BE
13142정성태10/18/202220405도서: 시작하세요! C# 12 프로그래밍
13141정성태10/17/202216139.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13140정성태10/11/202215530C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/202213628.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/202216221.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/202214138.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...