Das umfassende C# Cheat Sheet soll Entwicklern bei der Beherrschung der Schlüsselsyntax und Konzepte im Zusammenhang mit C# -Programmierung helfen.
Grundstruktur
Datentypen
Variablen
Konstanten
Bedingte Aussagen
Schleifen
Arrays
Listen
Wörterbücher
Methoden
Klassen & Objekte
Ausnahmebehandlung
Delegierte, Veranstaltungen und Lambdas
LINQ (Sprachintegrierte Abfrage)
Attribute
Asynchron/wartet
Verschiedenes
Streichmanipulation
Datei i/o
Datum und Uhrzeit
Generika
Nullables
Attribute & Reflexion
Verlängerungsmethoden
Abhängigkeitsinjektion
Teilklassen
Interoperabilität
Anonyme Typen
Tupel
Musteranpassung
Lokale Funktionen
Aufzeichnungen
mit Ausdrücken
Indexer und Bereiche
Verwenden von Deklaration
Nullierbare Referenztypen (NRTs)
Musterbasierte Verwendung
Eigenschaftsmuster
Standard -Schnittstellen -Implementierungen
Dynamische Bindung
Alle C# -Programme folgen einer grundlegenden Struktur, die unten beschrieben wird:
using System;
public class HelloWorld
{
public static void Main(string[] args)
{
Console.WriteLine("Hello, World!");
}
}
Beginnend mit .NET 5 vereinfachen Top-Level-Anweisungen das Programm. CS-Inhalt:
Console.WriteLine("Hello, World");
C# unterstützt verschiedene Datentypen wie:
Werttypen: int, char, float
Referenztypen: String, Klasse, Array
Variablen sind symbolische Namen für Werte:
int age = 30; // integer variable
string name = "John"; // string variable
double PI = 3.14159; // double for floating-point numbers
bool isLoggedIn = true; // boolean variable
Verwenden Sie 'var' für den Typ -Inferenz:
var number = 5; // compiler infers type as int
var message = "This is a message"; // compiler infers type as string
Konstanten haben unveränderliche Werte:
const double GRAVITY = 9.81; // constant for gravitational acceleration
const string COMPANY_NAME = "MyCompany"; // constant company name
Steuerungsprogrammfluss basierend auf Bedingungen:
int age = 20;
if (age >= 18)
{
Console.WriteLine("You are eligible to vote.");
}
else
{
Console.WriteLine("You are not eligible to vote.");
}
switch (variable) { /*...*/ } // Switch statement
Code wiederholt ausführen:
for (int i = 1; i <= 5; i++)
{
Console.WriteLine(i);
}
foreach (var item in collection) { /*...*/ } // Foreach loop
while (condition) { /*...*/ } // While loop
do { /*...*/ } while (condition); // Do-while loop
Elementersammlungen fester Größe:
string[] names = new string[3] { "Alice", "Bob", "Charlie" };
Console.WriteLine(names[1]); // Output: Bob (accessing element at index 1)
Dynamische Sammlungen ähnlich wie Arrays:
List<int> numbers = new List<int>();
numbers.Add(1);
numbers.Add(2);
numbers.Add(3);
foreach (var number in numbers)
{
Console.WriteLine(number);
}
Schlüsselwertpaare für die Datenvereinigung:
Dictionary<string, string> phonebook = new Dictionary<string, string>();
phonebook.Add("John Doe", "123-456-7890");
phonebook.Add("Jane Doe", "987-654-3210");
Console.WriteLine(phonebook["John Doe"]); // Output: 123-456-7890
Kapitäre wiederverwendbare Logik:
public class Rectangle
{
public double Width { get; set; }
public double Height { get; set; }
public double GetArea()
{
return Width * Height;
}
}
public class Program
{
public static void Main(string[] args)
{
Rectangle rect = new Rectangle();
rect.Width = 5;
rect.Height = 10;
double area = rect.GetArea();
Console.WriteLine($"Area of rectangle: {area}");
}
}
Klassen definieren Blaupausen für Objekte:
public class MyClass // Class definition
{
public string PropertyName { get; set; } // Properties store data
public void MethodName() { /*...*/ } // Methods define actions
}
MyClass obj = new MyClass(); // Object creation
Verwalten Sie die Laufzeitfehler anmutig:
public static int GetNumberInput()
{
while (true)
{
try
{
Console.WriteLine("Enter a number: ");
string input = Console.ReadLine();
return int.Parse(input);
}
catch (FormatException)
{
Console.WriteLine("Invalid input. Please enter a number.");
}
}
}
public static void Main(string[] args)
{
int number = GetNumberInput();
Console.WriteLine($"You entered: {number}");
}
Für ereignisgesteuerte Programmierung und Methodenhandhabung:
public delegate void MyDelegate(); // Delegate declaration
event MyDelegate MyEvent; // Event declaration
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
public static void Main(string[] args)
{
List<Person> people = new List<Person>()
{
new Person { Name = "Alice", Age = 30 },
new Person { Name = "Bob", Age = 25 },
new Person { Name = "Charlie", Age = 40 },
};
people.Sort((p1, p2) => p1.Name.CompareTo(p2.Name));
foreach (var person in people)
{
Console.WriteLine(person.Name); // Output: Alice, Bob, Charlie (sorted by name)
}
}
Abfragefunktionen für die Datenmanipulation:
using System.Linq;
public static void Main(string[] args)
{
List<int> numbers = new List<int>() { 1, 2, 3, 4, 5, 6 };
var evenNumbers = numbers.Where(x => x % 2 == 0);
foreach (var number in evenNumbers)
{
Console.WriteLine(number); // Output: 2, 4, 6
}
}
Metadaten zu Codeelementen hinzufügen:
[Obsolete("Use the new DoSomethingV2 method instead.")]
public void DoSomething()
{
// Implementation here
}
public void DoSomethingV2()
{
// New and improved implementation
}
Für nicht blockierende Codeausführung:
using System.Threading.Tasks;
public static async Task DownloadFileAsync(string url, string filePath)
{
// Simulate downloading data asynchronously
await Task.Delay(2000); // Simulate a 2-second download
// Write downloaded data to the file
File.WriteAllText(filePath, "Downloaded content");
Console.WriteLine($"File downloaded to: {filePath}");
}
public static void Main(string[] args)
{
string url = "https://example.com/data.txt";
string filePath = "downloaded_data.txt";
DownloadFileAsync(url, filePath);
// Continue program execution while download happens in the background
Console.WriteLine("Downloading file...");
Console.WriteLine("Meanwhile, you can do other things...");
}
Zusätzliche Sprachmerkmale:
Enum, Schnittstelle, Klasse, Aufzeichnung, Struktur
dynamisch, ist, wie var, nameof
Leistungsstarke Stringhandhabungsmethoden:
string.Concat(); // Combine strings
string.Join(); // Join elements
str.Split(); // Split string
str.ToUpper(); // Convert to uppercase
str.ToLower(); // Convert to lowercase
Vorgänge mit Dateien:
using System.IO; // Required for File I/O
File.ReadAllText(path); // Read file content
File.WriteAllText(path, content); // Write to file
File.Exists(path); // Check file existence
Datum und Uhrzeitmanipulation:
using System;
public static void Main(string[] args)
{
DateTime startDate = DateTime.Parse("2024-03-10");
DateTime endDate = DateTime.Now;
TimeSpan difference = endDate - startDate;
Console.WriteLine($"Time difference: {difference.Days} days, {difference.Hours} hours");
}
Datenstrukturen vom Typ Safe:
public class Stack<T>
{
private List<T> items = new List<T>();
public void Push(T item)
{
items.Add(item);
}
public T Pop()
{
T item = items[items.Count - 1];
items.RemoveAt(items.Count - 1);
return item;
}
}
public static void Main(string[] args)
{
Stack<string> messages = new Stack<string>();
messages.Push("Hello");
messages.Push("World");
string message = messages.Pop();
Console.WriteLine(message); // Output: World
}
Lassen Sie die Werttypen null sein:
int? nullableInt = null; // Nullable integer
Metadaten und Typenbeobachtung:
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
public static void Main(string[] args)
{
Type personType = typeof(Person);
PropertyInfo[] properties = personType.GetProperties();
foreach (PropertyInfo property in properties)
{
Console.WriteLine(property.Name); // Output: Name, Age
}
}
Methoden zu vorhandenen Typen hinzufügen:
public static class StringExtensions
{
public static string ToUppercase(this string str)
{
return str.ToUpper();
}
}
public static void Main(string[] args)
{
string message = "Hello, world!";
string uppercased = message.ToUppercase(); // Using the extension method
Console.WriteLine(uppercased); // Output: HELLO, WORLD!
}
Locker gekoppelter Code -Design:
public interface ILogger
{
void LogMessage(string message);
}
public class MyService
{
private readonly ILogger _logger;
public MyService(ILogger logger)
{
_logger = logger;
}
public void DoSomething()
{
_logger.LogMessage("Doing something...");
}
}
// Implementing the ILogger interface (example)
public class ConsoleLogger : ILogger
{
public void LogMessage(string message)
{
Console.WriteLine(message);
}
}
public static void Main(string[] args)
{
ILogger logger = new ConsoleLogger();
MyService service = new MyService(logger);
service.DoSomething();
}
Aufteilung einer einzelnen Klassendefinition:
public partial class MyClass { /*...*/ } // Partial class definition
Interop mit anderen Sprachen:
using System;
using System.Runtime.InteropServices;
[DllImport("user32.dll")]
public static extern int MessageBox(IntPtr hWnd, string lpText, string lpCaption, uint uType);
public static void Main(string[] args)
{
MessageBox(IntPtr.Zero, "Hello from C#!", "Interop Example", 0);
}
Erstellen unbenannter Typen: CSHARPCOPY -Code
var person = new { Name = "John", Age = 30 };
Console.WriteLine($"Name: {person.Name}, Age: {person.Age}");
Datenstrukturen mit einer bestimmten Anzahl von Elementen:
(string Name, int Age) person = ("Alice", 30);
Console.WriteLine($"Name: {person.Name}, Age: {person.Age}"); // Accessing elements using Item1 and Item2
Vereinfacht bestimmte Programmieraufgaben:
object obj = new Person { Name = "Bob", Age = 25 };
if (obj is Person { Name: "Bob", Age >= 18 })
{
Console.WriteLine("Bob is an adult.");
}
Logik in Methoden einkapseln:
public static int Calculate(int number)
{
int Factorial(int n)
{
if (n == 0) return 1;
return n * Factorial(n - 1);
}
return Factorial(number);
}
public static void Main(string[] args)
{
int result = Calculate(5);
Console.WriteLine($"5! = {result}");
}
Präzise Syntax für Referenztypen:
public record Person(string Name, int Age);
public static void Main(string[] args)
{
Person person1 = new Person("Alice", 30);
Person person2 = new Person("Alice", 30);
// Records provide default equality comparison
if (person1 == person2)
{
Console.WriteLine("People are equal");
}
}
Nicht-zerstörerische Mutation für Aufzeichnungen:
var john = new Person("John", 30);
var jane = john with { Name = "Jane" }; // Non-destructive mutation
Flexibler Datenzugriff:
int[] arr = {0, 1, 2, 3, 4, 5};
var subset = arr[1..^1]; // Indexer and range usage
Idisposable Objekte entsorgen:
using var reader = new StreamReader("file.txt"); // using declaration
Vermeiden Sie Null -Referenz -Ausnahmen:
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
public static void Main(string[] args)
{
Person person = new Person() { Age = 30 };
// NRTs require null checks before accessing properties
if (person?.Name != null)
{
Console.WriteLine(person.Name);
}
else
{
Console.WriteLine("Name is null");
}
}
Weitere Muster in der Verwendung von Anweisung:
public ref struct ResourceWrapper { /*...*/ } // Resource wrapper
using var resource = new ResourceWrapper(); // Pattern-based using
Dekonstruktion von Objekten in der Musteranpassung:
if (obj is Person { Name: "John", Age: var age }) { /*...*/ } // Property pattern matching
Schnittstellen mit Standardmethodenimplementierungen:
public interface IPerson { /*...*/ } // Interface with default method
public class MyClass : IPerson { /*...*/ } // Class implementing interface
Laufzeit -Typ -Auflösung:
dynamic d = 5; // Dynamic binding
d = "Hello"; // No compile-time type checking
Dieses strukturierte C# Cheat Sheet schließt mit fortgeschrittenen Themen und Techniken und bietet eine umfassende Referenz für Entwickler, die ihre C# -Perenzierkenntnisse verbessern möchten. Ausführliche Beispiele und weitere Erkundungen finden Sie in den in diesem Handbuch beschriebenen Abschnitten. Happy Coding!
Inspiriert von: https://zerotomastery.io/cheatsets/csharp-teetsgeeet/#constants