Dela via


C#-kompilatoralternativ för språkfunktionsregler

Följande alternativ styr hur kompilatorn tolkar språkfunktioner. Den nya MSBuild-syntaxen visas i Fetstil. Den äldre csc.exe syntaxen visas i code style.

  • CheckForOverflowUnderflow / -checked: Generera spillkontroller.
  • AllowUnsafeBlocks / -unsafe: Tillåt "osäker" kod.
  • DefineConstants: Definiera villkorsstyrda kompileringssymboler / -define.
  • LangVersion / -langversion: Ange språkversion som default (senaste huvudversion) eller latest (senaste version, inklusive delversioner).
  • Nullbar / -nullable: Aktivera nullbar kontext eller nullbara varningar.

CheckForOverflowUnderflow

Alternativet CheckForOverflowUnderflow styr standardkontexten för spillkontroll som definierar programmets beteende om heltalsaritmetiska spill.

<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>

När CheckForOverflowUnderflow är trueär standardkontexten en markerad kontext och spillkontroll är aktiverad. Annars är standardkontexten en omarkerad kontext. Standardvärdet för det här alternativet är false, d.v.s. spillkontroll är inaktiverat.

Du kan också uttryckligen styra överflödeskontrollkontexten för delar av koden med hjälp av instruktionen checked och unchecked .

Information om hur överflödeskontrollkontexten påverkar åtgärder och vilka åtgärder som påverkas finns i artikeln om checked och unchecked -instruktioner.

AllowUnsafeBlocks

Kompileringsalternativet AllowUnsafeBlocks tillåter kod som använder det osäkra nyckelordet för kompilering. Standardvärdet för det här alternativet är false, vilket innebär att osäker kod inte tillåts.

<AllowUnsafeBlocks>true</AllowUnsafeBlocks>

Mer information om osäker kod finns i Osäker kod och pekare.

DefineConstants

Alternativet DefineConstants definierar symboler i alla källkodsfiler i ditt program.

<DefineConstants>name;name2</DefineConstants>

Det här alternativet anger namnen på en eller flera symboler som du vill definiera. Alternativet DefineConstants har samma effekt som det #define förprocessordirektivet, förutom att kompilatoralternativet gäller för alla filer i projektet. En symbol förblir definierad i en källfil tills ett #undef-direktiv i källfilen tar bort definitionen. När du använder -define alternativet har ett #undef direktiv i en fil ingen effekt på andra källkodsfiler i projektet. Du kan använda symboler som skapats med det här alternativet med #if, #else, #elif och #endif för att kompilera källfiler villkorligt. Själva C#-kompilatorn definierar inga symboler eller makron som du kan använda i källkoden. alla symboldefinitioner måste vara användardefinierade.

Kommentar

C#- #define direktivet tillåter inte att en symbol får ett värde, som på språk som C++. Kan till exempel #define inte användas för att skapa ett makro eller för att definiera en konstant. Om du behöver definiera en konstant använder du en enum variabel. Om du vill skapa ett C++-formatmakron bör du överväga alternativ som generiska objekt. Eftersom makron är notoriskt felbenägna tillåter C# inte användning men ger säkrare alternativ.

LangVersion

Standardspråkversionen för C#-kompilatorn beror på målramverket för ditt program och vilken version av SDK eller Visual Studio som är installerad. Dessa regler definieras i C#-språkversioner.

Varning

Det rekommenderas inte att ange elementet LangVersion till latest . Inställningen latest innebär att den installerade kompilatorn använder sin senaste version. Det kan ändras från dator till dator, vilket gör byggen otillförlitliga. Dessutom möjliggör den språkfunktioner som kan kräva körnings- eller biblioteksfunktioner som inte ingår i den aktuella SDK:t.

Alternativet LangVersion gör att kompilatorn endast accepterar syntax som ingår i den angivna C#-språkspecifikationen, till exempel:

<LangVersion>9.0</LangVersion>

Följande värden är giltiga:

Värde Innebörd
preview Kompilatorn accepterar alla giltiga språksyntaxer från den senaste förhandsversionen.
latest Kompilatorn accepterar syntax från den senaste versionen av kompilatorn (inklusive delversion).
latestMajor
eller default
Kompilatorn accepterar syntax från den senaste versionen av huvudversionen av kompilatorn.
13.0 Kompilatorn accepterar endast syntax som ingår i C# 13 eller lägre.
12.0 Kompilatorn accepterar endast syntax som ingår i C# 12 eller lägre.
11.0 Kompilatorn accepterar endast syntax som ingår i C# 11 eller lägre.
10.0 Kompilatorn accepterar endast syntax som ingår i C# 10 eller lägre.
9.0 Kompilatorn accepterar endast syntax som ingår i C# 9 eller lägre.
8.0 Kompilatorn accepterar endast syntax som ingår i C# 8.0 eller lägre.
7.3 Kompilatorn accepterar endast syntax som ingår i C# 7.3 eller lägre.
7.2 Kompilatorn accepterar endast syntax som ingår i C# 7.2 eller lägre.
7.1 Kompilatorn accepterar endast syntax som ingår i C# 7.1 eller lägre.
7 Kompilatorn accepterar endast syntax som ingår i C# 7.0 eller lägre.
6 Kompilatorn accepterar endast syntax som ingår i C# 6.0 eller lägre.
5 Kompilatorn accepterar endast syntax som ingår i C# 5.0 eller lägre.
4 Kompilatorn accepterar endast syntax som ingår i C# 4.0 eller lägre.
3 Kompilatorn accepterar endast syntax som ingår i C# 3.0 eller lägre.
ISO-2
eller 2
Kompilatorn accepterar endast syntax som ingår i ISO/IEC 23270:2006 C# (2.0).
ISO-1
eller 1
Kompilatorn accepterar endast syntax som ingår i ISO/IEC 23270:2003 C# (1.0/1.2).

Att tänka på

  • Använd inte alternativet LangVersion för att säkerställa att ditt projekt använder den standardkompilatorversion som rekommenderas för ditt målramverk. Du kan uppdatera målramverket för att få åtkomst till nyare språkfunktioner.

  • Att ange LangVersion med default värdet skiljer sig från att utelämna alternativet LangVersion . När du anger default används den senaste versionen av språket som kompilatorn stöder, utan att ta hänsyn till målramverket. Om du till exempel skapar ett projekt som riktar sig mot .NET 6 från Visual Studio version 17.6 används C# 10 om LangVersion inte har angetts, men använder C# 11 om LangVersion är inställt på default.

  • Metadata som refereras av C#-programmet omfattas inte av kompilatoralternativet LangVersion .

  • Eftersom varje version av C#-kompilatorn innehåller tillägg till språkspecifikationen ger LangVersion inte motsvarande funktioner i en tidigare version av kompilatorn.

  • Även om C#-versionsuppdateringar vanligtvis sammanfaller med större .NET-versioner, är den nya syntaxen och funktionerna inte nödvändigtvis knutna till den specifika ramverksversionen. Varje specifik funktion har ett eget minimikrav för .NET API eller vanliga språkkörningskrav som gör att den kan köras på ramverk på nednivå genom att inkludera NuGet-paket eller andra bibliotek.

  • Oavsett vilken LangVersion-inställning du använder använder du den aktuella versionen av den vanliga språkkörningen för att skapa .exe eller .dll. Ett undantag är vänsammansättningar och ModuleAssemblyName, som fungerar under -langversion:ISO-1.

Andra sätt att ange C#-språkversionen finns i C#-språkversioner.

Information om hur du ställer in det här kompilatoralternativet programmatiskt finns i LanguageVersion.

Språkspecifikation för C#

Version Länk beskrivning
C# 8.0 och senare ladda ned PDF C#-språkspecifikation version 7: .NET Foundation
C# 7.3 ladda ned PDF Standard ECMA-334 7th Edition
C# 6.0 ladda ned PDF Standard ECMA-334 6th Edition
C# 5.0 Ladda ned PDF Standard ECMA-334 5th Edition
C# 3.0 Ladda ned DOC C# Language Specification Version 3.0: Microsoft Corporation
C# 2.0 Ladda ned PDF Standard ECMA-334 4th Edition
C# 1.2 Ladda ned DOC Standard ECMA-334 2nd Edition
C# 1.0 Ladda ned DOC Standard ECMA-334 1st Edition

Lägsta SDK-version som krävs för att stödja alla språkfunktioner

I följande tabell visas de lägsta versionerna av SDK:t med C#-kompilatorn som stöder motsvarande språkversion:

C#-version Minimum SDK-version
C# 12 Microsoft Visual Studio/Build Tools 2022 version 17.8 eller .NET 8 SDK
C# 11 Microsoft Visual Studio/Build Tools 2022 version 17.4 eller .NET 7 SDK
C# 10 Microsoft Visual Studio/Build Tools 2022 eller .NET 6 SDK
C# 9.0 Microsoft Visual Studio/Build Tools 2019 version 16.8 eller .NET 5 SDK
C# 8.0 Microsoft Visual Studio/Build Tools 2019, version 16.3 eller .NET Core 3.0 SDK
C# 7.3 Microsoft Visual Studio/Build Tools 2017, version 15.7
C# 7.2 Microsoft Visual Studio/Build Tools 2017, version 15.5
C# 7.1 Microsoft Visual Studio/Build Tools 2017, version 15.3
C# 7.0 Microsoft Visual Studio/Build Tools 2017
C# 6 Microsoft Visual Studio/Build Tools 2015
C# 5 Microsoft Visual Studio/Build Tools 2012 eller en paketerad .NET Framework 4.5-kompilator
C# 4 Microsoft Visual Studio/Build Tools 2010 eller en paketerad .NET Framework 4.0-kompilator
C# 3 Microsoft Visual Studio/Build Tools 2008 eller en paketerad .NET Framework 3.5-kompilator
C# 2 Microsoft Visual Studio/Build Tools 2005 eller en paketerad .NET Framework 2.0-kompilator
C# 1.0/1.2 Microsoft Visual Studio/Build Tools .NET 2002 eller en paketerad .NET Framework 1.0-kompilator

Kan ha värdet null

Med alternativet Nullable kan du ange den nullbara kontexten. Den kan anges i projektets konfiguration med hjälp av taggen <Nullable> :

<Nullable>enable</Nullable>

Argumentet måste vara ett av enable, disable, warningseller annotations. Argumentet enable aktiverar den nullbara kontexten. Om du anger disable inaktiveras den nullbara kontexten. När du anger warnings argumentet aktiveras den nullbara varningskontexten. När du anger annotations argumentet aktiveras den nullbara anteckningskontexten. Värdena beskrivs och förklaras i artikeln om nullbara kontexter. Du kan lära dig mer om de uppgifter som ingår i aktivering av nullbara referenstyper i en befintlig kodbas i vår artikel om nullbara migreringsstrategier.

Kommentar

När det inte finns någon värdeuppsättning tillämpas standardvärdet disable , men .NET 6-mallarna tillhandahålls som standard med värdet Nullable inställt på enable.

Flödesanalys används för att härleda variablernas nullbarhet i körbar kod. Den härledda nullabiliteten för en variabel är oberoende av variabelns deklarerade nullabilitet. Metodanrop analyseras även när de utelämnas villkorligt. Till exempel Debug.Assert i versionsläge.

Anrop av metoder som har kommenterats med följande attribut påverkar också flödesanalysen:

Viktigt!

Den globala nullbara kontexten gäller inte för genererade kodfiler. Oavsett den här inställningen inaktiveras den nullbara kontexten för alla källfiler som har markerats som genererade. Det finns fyra sätt som en fil markeras som genererad:

  1. I .editorconfig anger du generated_code = true i ett avsnitt som gäller för filen.
  2. Placera <auto-generated> eller <auto-generated/> i en kommentar överst i filen. Det kan finnas på valfri rad i kommentaren, men kommentarsblocket måste vara det första elementet i filen.
  3. Starta filnamnet med TemporaryGeneratedFile_
  4. Avsluta filnamnet med .designer.cs, .generated.cs, .g.cs eller .g.i.cs.

Generatorer kan välja att använda #nullable förprocessordirektivet.