C #의 올바른 버전 번호는 무엇입니까? 언제 나왔어? C # 3.5에 대한 답변을 찾을 수없는 이유는 무엇 입니까?
이 질문은 주로 잘못된 버전 번호 (예 : C # 3.5)를 사용하여 답변을 검색하는 사람들을 돕기위한 것 입니다. 버전 번호가 잘못된 답변을 찾지 못한 사람은 이 질문을 찾은 다음 올바른 버전 번호로 다시 검색 하기를 희망 합니다.
C #의 올바른 버전 번호는 무엇입니까? 언제 나왔어? C # 3.5에 대한 답변을 찾을 수없는 이유는 무엇 입니까?
이 질문은 주로 잘못된 버전 번호 (예 : C # 3.5)를 사용하여 답변을 검색하는 사람들을 돕기위한 것 입니다. 버전 번호가 잘못된 답변을 찾지 못한 사람은 이 질문을 찾은 다음 올바른 버전 번호로 다시 검색 하기를 희망 합니다.
답변:
이 글을 쓰는 시점에 알려진 C # 버전은 다음과 같습니다.
Dispose
에 IEnumerator
구현의 IDisposable
. 다른 작은 기능들.var
), 쿼리 식dynamic
), 델리게이트 및 인터페이스 일반 분산, 추가 COM 지원, 명명 된 인수, 튜플 데이터 형식 및 선택적 매개 변수await
in catch
, 및 컬렉션 초기화 finally
프로그램의 확장 Add
메소드.out
매개 변수 선언 , 로컬 함수 , 이진 리터럴, 숫자 구분 기호 및 임의의 비동기 리턴 .unmanaged
제네릭 형식 제약 . ref
재 할당. 안전하지 않은 개선 : stackalloc
초기화, 고정되지 않은 인덱스 fixed
버퍼, 사용자 지정 fixed
문 오버로드 해상도가 향상되었습니다. 이니셜 라이저 및 쿼리의 표현식 변수 ==
및 !=
튜플에 대해 정의. 자동 속성의 지원 필드는 이제 속성으로 타겟팅 할 수 있습니다.new
표현식, 대상 유형 ??
및 ?
), 공변량을 반환합니다. 사소한 기능 : 순서 ref
및 partial
수정 자 완화 , 매개 변수 null 검사, 람다 삭제 매개 변수, native int
, 로컬 함수의 속성, 함수 포인터, 정적 람다, 확장 GetEnumerator
, 모듈 이니셜 라이저, 부분 확장.C #의 올바른 버전 번호는 무엇입니까? 언제 나왔어? C # 3.5에 대한 답변을 찾을 수없는 이유는 무엇입니까?
C # 3.5와 같은 것은 없습니다. 혼동의 원인은 C # 3.0이 .NET 3.5에 있다는 것입니다. 그러나 언어와 프레임 워크는 독립적으로 버전이 지정됩니다. CLR과 마찬가지로 .NET 2.0에서 3.5 버전 2.0, CLR 4.0을 도입 한 .NET 4 버전, 서비스 팩에도 불구하고. .NET 4.5의 CLR은 여러 가지 개선 사항이 있지만 버전 관리가 불분명합니다. 어떤 곳에서는 CLR 4.5 (예 : 이 MSDN 페이지 에서이를 참조하는 데 사용됨)라고 할 수 있지만 Environment.Version
속성은 여전히 4.0을보고합니다. 트리플 엑스.
2017 년 5 월 3 일부터 C # 언어 팀은 GitHub 리포지토리에 C # 버전 및 기능에 대한 기록을 만들었습니다 . C # 언어 버전에 추가 된 기능 . 다가오는 최신 언어 기능을 추적하는 페이지 도 있습니다 .
이것은 대부분의 답변과 동일하지만 쉽게 표 형식으로 표시되며 완전성을 위해 Visual Studio 및 .NET 버전이 있습니다.
╔════════════╦════════════╦══════════════╦═════════════╦══════════════╗
║ C# version ║ VS version ║ .NET version ║ CLR version ║ Release date ║
╠════════════╬════════════╬══════════════╬═════════════╬══════════════╣
║ 1.0 ║ 2002 ║ 1.0 ║ 1.0 ║ Feb 2002 ║
║ 1.2 ║ 2003 ║ 1.1 ║ 1.1 ║ Apr 2003 ║
║ 2.0 ║ 2005 ║ 2.0 ║ 2.0 ║ Nov 2005 ║
║ ║ ║ 3.0 ║ 2.0 ║ Nov 2006 ║
║ 3.0 ║ 2008 ║ 3.5 ║ 2.0 ║ Nov 2007 ║
║ 4.0 ║ 2010 ║ 4.0 ║ 4 ║ Apr 2010 ║
║ 5.0 ║ 2012 ║ 4.5 ║ 4 ║ Aug 2012 ║
║ 5.0 ║ 2013 ║ 4.5.1 ║ 4 ║ Oct 2013 ║
║ ║ ║ 4.5.2 ║ 4 ║ May 2014 ║
║ 6.0 ║ 2015 ║ 4.6 ║ 4 ║ Jul 2015 ║
║ ║ ║ 4.6.1 ║ 4 ║ Nov 2015 ║
║ ║ ║ 4.6.2 ║ 4 ║ Aug 2016 ║
║ 7.0 ║ 2017 ║ ║ ║ Mar 2017 ║
║ ║ ║ 4.7 ║ 4 ║ May 2017 ║
║ 7.1 ║ 2017(v15.3)║ ║ ║ Aug 2017 ║
║ ║ ║ 4.7.1 ║ 4 ║ Oct 2017 ║
║ 7.2 ║ 2017(v15.5)║ ║ ║ Dec 2017 ║
║ ║ ║ 4.7.2 ║ 4 ║ Apr 2018 ║
║ 7.3 ║ 2017(v15.7)║ ║ ║ May 2018 ║
║ 8.0 ║ 2019 ║ 4.8 ║ 4 ║ Apr 2019 ║
╚════════════╩════════════╩══════════════╩═════════════╩══════════════╝
참고 : .NET 개발은 요즘 VS와 거의 독립적이며 각 버전 사이에는 상관 관계가 없습니다.
자세한 내용은 " .NET Framework 버전 및 종속성 "을 참조하십시오.
C #의 버전 번호를 처리 할 때 가장 큰 문제는 Visual Studio와 .NET Framework 간의 동기화 된 릴리스 때문인 것으로 보이는 .NET Framework 버전과 관련이 없다는 사실입니다.
C #의 버전은 실제로 프레임 워크가 아닌 컴파일러에 바인딩됩니다. 예를 들어 Visual Studio 2008에서는 C # 3.0을 작성하고 .NET Framework 2.0, 3.0 및 3.5를 대상으로 할 수 있습니다. C # 3.0 명명법은 ANSI C89, C90, C99 가 C의 코드 구문 / 기능을 설명하는 것과 동일한 방식으로 코드 구문의 버전과 지원되는 기능을 설명합니다.
Mono를 살펴보면 Mono 2.0 (주로 ECMA 사양에서 구현 된 .NET Framework 버전 2.0)이 C # 3.0 구문과 기능을 지원한다는 것을 알 수 있습니다.
버전_____
언어 사양 ______
MICROSOFT COMPILER
C # 1.0 / 1.2____
2001 년 12 월 ? / 2003 ? ___________
2002 년 1 월 ?
C # 2.0 _______
2005 년 9 월 2005 년________________
11 월 ?
C # 3.0 _______
2006 년 5 월 2006 년_____________________
11 월 ?
C # 4.0 _______
2009 년 3 월 (초안)______________
2010 년 4 월 ?
C # 5.0; 2012 년 8 월 .NET 4.5와 함께 출시
C # 6.0; .NET 4.6 2015와 함께 출시
C # 7.0; .NET 4.7 2017과 함께 출시
C # 8.0; .NET 4.8 2019로 출시
이 표에서 대부분의 버전을 요약했습니다. 유일하게 누락 된 것은 ASP.NET Core 버전이어야합니다. 다른 버전의 ASP.NET MVC도 추가했습니다.
ASP.NET 5는 ASP.NET Core 1.0으로 이름이 변경되었으며 ASP.NET MVC 6은 ASP.NET Core MVC 1.0.0으로 이름이 변경되었습니다. 나는이 변화가 2016 년 1 월경 쯤에 일어났다 고 생각합니다.
표에 ASP.NET 5 RC1의 릴리스 날짜를 포함 시켰지만 정확한 릴리스 날짜를 찾을 수 없기 때문에 아직 ASP.NET 코어 1.0 및 기타 코어 버전을 포함시키지 않았습니다. ASP.NET Core 관련 릴리스 날짜에 대한 자세한 내용은 다음을 참조하십시오. ASP.NET Core 1.0 (ASP.NET 5 / vNext)은 언제 출시 될 예정입니까?
여기 에서 최신 C # 버전을 확인할 수 있습니다
MSDN 기사 "C # 2.0 언어 및 컴파일러 의 새로운 기능 " 및 " Visual C # 2005의 새로운 기능 "을 비교하면 컴파일러 버전 번호에 따라 "C # major_version.minor_version"이 만들어지는 것으로 추론 할 수 있습니다.
거기 C # 1.2 .NET 1.1 VS 2003에 대응 하며로 명명 카메라 C # 1 .NET 2003 .
그러나 Microsoft는 마이너 버전 (점 뒤)을 늘리거나 0 이외의 숫자를 갖기 위해 더 이상 중단하지 않았습니다 0
. .NET 3.5에 해당하는 C #은 msdn.microsoft.com에서 "Visual C # 2008 Service Pack 1" 로 명명됩니다 .
주요 .NET / 컴파일러 버전 번호 매기기 및 Visual Studio 번호 매기기의 두 가지 병렬 명명이 있습니다.
C # 2.0 은 Visual C # 2005 의 동의어입니다.
C # 3.0은 다음에 해당하거나보다 정확하게 타겟팅 할 수 있습니다.
Classes
Structs
Interfaces
Events
Properties
Delegates
Expressions
Statements
Attributes
Literals
Dispose in foreach
foreach over string specialization
C# 2 - Visual Studio 2005
Generics
Partial types
Anonymous methods
Iterators
Nullable types
Getter/setter separate accessibility
Method group conversions (delegates)
Static classes
Delegate inference
Implicitly typed local variables
Object and collection initializers
Auto-Implemented properties
Anonymous types
Extension methods
Query expressions
Lambda expression
Expression trees
Partial methods
Dynamic binding
Named and optional arguments
Co- and Contra-variance for generic delegates and interfaces
Embedded interop types ("NoPIA")
Asynchronous methods
Caller info attributes
Draft Specification online
Compiler-as-a-service (Roslyn)
Import of static type members into namespace
Exception filters
Await in catch/finally blocks
Auto property initializers
Default values for getter-only properties
Expression-bodied members
Null propagator (null-conditional operator, succinct null checking)
String interpolation
nameof operator
Dictionary initializer
Out variables
Pattern matching
Tuples
Deconstruction
Discards
Local Functions
Binary Literals
Digit Separators
Ref returns and locals
Generalized async return types
More expression-bodied members
Throw expressions
Async main
Default expressions
Reference assemblies
Inferred tuple element names
Pattern-matching with generics
Span and ref-like types
In parameters and readonly references
Ref conditional
Non-trailing named arguments
Private protected accessibility
Digit separator after base specifier
System.Enum, System.Delegate and unmanaged constraints.
Ref local re-assignment: Ref locals and ref parameters can now be reassigned with the ref assignment operator (= ref).
Stackalloc initializers: Stack-allocated arrays can now be initialized, e.g. Span<int> x = stackalloc[] { 1, 2, 3 };.
Indexing movable fixed buffers: Fixed buffers can be indexed into without first being pinned.
Custom fixed statement: Types that implement a suitable GetPinnableReference can be used in a fixed statement.
Improved overload candidates: Some overload resolution candidates can be ruled out early, thus reducing ambiguities.
Expression variables in initializers and queries: Expression variables like out var and pattern variables are allowed in field initializers, constructor initializers and LINQ queries.
Tuple comparison: Tuples can now be compared with == and !=.
Attributes on backing fields: Allows [field: …] attributes on an auto-implemented property to target its backing field.
Nullable reference types: express nullability intent on reference types with ?, notnull constraint and annotations attributes in APIs, the compiler will use those to try and detect possible null values being dereferenced or passed to unsuitable APIs.
Default interface members: interfaces can now have members with default implementations, as well as static/private/protected/internal members except for state (ie. no fields).
Recursive patterns: positional and property patterns allow testing deeper into an object, and switch expressions allow for testing multiple patterns and producing corresponding results in a compact fashion.
Async streams: await foreach and await using allow for asynchronous enumeration and disposal of IAsyncEnumerable<T> collections and IAsyncDisposable resources, and async-iterator methods allow convenient implementation of such asynchronous streams.
Enhanced using: a using declaration is added with an implicit scope and using statements and declarations allow disposal of ref structs using a pattern.
Ranges and indexes: the i..j syntax allows constructing System.Range instances, the ^k syntax allows constructing System.Index instances, and those can be used to index/slice collections.
Null-coalescing assignment: ??= allows conditionally assigning when the value is null.
Static local functions: local functions modified with static cannot capture this or local variables, and local function parameters now shadow locals in parent scopes.
Unmanaged generic structs: generic struct types that only have unmanaged fields are now considered unmanaged (ie. they satisfy the unmanaged constraint).
Readonly members: individual members can now be marked as readonly to indicate and enforce that they do not modify instance state.
Stackalloc in nested contexts: stackalloc expressions are now allowed in more expression contexts.
Alternative interpolated verbatim strings: @$"..." strings are recognized as interpolated verbatim strings just like $@"...".
Obsolete on property accessors: property accessors can now be individually marked as obsolete.
Permit t is null on unconstrained type parameter
[출처] : https://github.com/dotnet/csharplang/blob/master/Language-Version-History.md
C # 8.0은 최신 버전의 c # .it이며 .NET Core 3.x 이상 버전에서만 지원됩니다. 최신 기능을 많이 사용하려면 .NET Core 3.x에 도입 된 라이브러리 및 런타임 기능이 필요합니다.
다음 표는 버전 및 기본 C # 버전이있는 대상 프레임 워크를 보여줍니다.