Statische Methoden in C# / .NET

Statische Methoden in C# / .NET

Statische Methoden in C# sind Methoden, die auf eine Klasse und nicht auf eine bestimmte Instanz einer Klasse angewendet werden. Sie können aufgerufen werden, ohne dass zuvor eine Instanz der Klasse erstellt wurde. Ein Beispiel für eine statische Methode ist die Math.Sqrt() Methode, die die Quadratwurzel einer Zahl berechnet.

Man sollte statische Methoden verwenden, wenn die Methode keinen Zugriff auf Instanzvariablen oder -methoden benötigt und wenn die Methode keine Änderungen an der Instanz vornimmt. Ein weiteres gutes Beispiel für die Verwendung von statischen Methoden ist die Erstellung von Hilfsmethoden, die von mehreren Klassen aufgerufen werden können, ohne dass eine Instanz erstellt werden muss.

Man sollte jedoch nicht statische Methoden verwenden, wenn die Methode auf Instanzvariablen oder -methoden zugreifen muss oder wenn die Methode Änderungen an der Instanz vornimmt. Ein klassischer Fall wäre zum Beispiel ein Datenbankzugriff: die Abfrage sollte niemals statisch sein, da sie schließlich eine Verbindung benötigt. Es sollte unbedingt vermieden werden, dass eine statische Methode interne Abhängigkeiten hat.

Vorteile von statischen Methoden:

  • Sie können ohne dass eine Instanz erstellt werden muss aufgerufen werden.
  • Sie können von mehreren Klassen aufgerufen werden, sind also unabhängig.
  • Sie können die Verwendung von globalen Variablen und Funktionen vermeiden.
  • Sie sind in der Runtime effizienter; richtig eingesetzt haben sie also einen Performance-Vorteil.

Nachteile von statischen Methoden:

  • Sie haben keinen Zugriff auf Instanzvariablen und -methoden.
  • Sie können nicht (so einfach)überschrieben werden.
  • Sie können nicht von abgeleiteten Klassen aufgerufen werden.
  • Sie können nicht (durch Mocking) getestet werden.

Tatsächliche Anwendung

In der realen Welt haben statische Methoden tägliche Anwendungszwecke; sei es Erweiterungsmethoden, funktionale Umsetzung oder tatsächliche Logik. Es ist im Endeffekt alles eine Frage der Anwendung. Statische Methoden können sehr effizient auch in einer OOP-Sprache wie C# angwendet werden; moderne Frameworks haben sehr viel funktionale Umsetzungen.

Die neue ASP.NET Core Minimal API fokussiert dabei sogar funktionale Umsetzungen.

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

app.MapGet("/", HelloHandler.Hello);

app.Run();

static class HelloHandler
{
    public static string Hello() // static
    {
        return "Hello static method";
    }
}

Abhängigkeiten werden über die Methode des Handlers mitgeliefert, der selbst statisch ist. Der enorme Vorteil dieses Wegs ist, dass im Gegensatz zu großen Controllern wirklich nur die Abhängigkeiten mitgeliefert werden, die tatsächlich notwendig sind. Auch sind kleinere Code-Bausteine in den Handlern möglich.


Zusammenfassend lässt sich sagen, dass statische Methoden eine nützliche Funktion in C# darstellen, die jedoch sorgfältig verwendet werden sollten, um sicherzustellen, dass sie in der richtigen Situation und zur Lösung des richtigen Problems eingesetzt werden.