Was ist „verwalteter Code“?

Bei der Arbeit mit .NET begegnen Sie häufig dem Begriff „verwalteter Code“. In diesem Artikel wird erläutert, was verwalteter Code bedeutet, und es werden zusätzliche Informationen dazu bereitgestellt.

Sehr einfach ausgedrückt, ist verwalteter Code genau das, was der Name besagt: Code, dessen Ausführung von einer Runtime verwaltet wird. In diesem Fall wird die betreffende Runtime als Common Language Runtime oder CLR bezeichnet, unabhängig von der Implementierung (z. B. Mono, .NET Framework oder .NET Core/.NET 5 und höher). Die CLR übernimmt die Aufgabe, den verwalteten Code in Computercode zu kompilieren und dann auszuführen. Darüber hinaus bietet die Common Language Runtime mehrere wichtige Dienste wie z. B. die automatische Arbeitsspeicherverwaltung, Sicherheitsgrenzen und Typsicherheit.

Vergleichen Sie dies mit der Art und Weise, auf die Sie ein C-/C++-Programm ausführen, dem sogenannten „nicht verwalteten Code“. Im nicht verwalteten Bereich ist der Programmierer für nahezu alles zuständig. Das tatsächliche Programm ist im Wesentlichen eine Binärdatei, die vom Betriebssystem in den Arbeitsspeicher geladen und gestartet wird. Alles Übrige, von der Arbeitsspeicherverwaltung bis hin zu den Sicherheitsaspekten, liegt in der Verantwortung des Programmierers.

Verwalteter Code wird in einer der allgemeinen Sprachen geschrieben, die auf .NET ausgeführt werden können, z.B. C#, Visual Basic, F# und andere. Wenn Sie in diesen Sprachen geschriebenen Code mit ihrem jeweiligen Compiler kompilieren, erhalten Sie keinen Computercode. Sie erhalten Code in einer Zwischensprache, Intermediate Language, der von der Runtime kompiliert und ausgeführt wird. C++ ist die einzige Ausnahme von dieser Regel, da diese Sprache auch native, nicht verwaltete Binärdateien erstellen kann, die unter Windows ausgeführt werden.

Zwischensprache (Intermediate Language) und Ausführung

Was ist eine Zwischensprache (Intermediate Language, kurz IL)? Dies ist ein Produkt der Kompilierung von Code, der in allgemeinen .NET-Sprachen geschrieben wurde. Nachdem Sie den Code kompiliert haben, der in einer dieser Sprachen geschrieben wurde, erhalten Sie eine Binärdatei, die aus IL besteht. Beachten Sie unbedingt, dass der IL-Code unabhängig von einer bestimmten Sprache ist, die auf der Runtime ausgeführt wird. Es gibt sogar eine separate Spezifikation dafür, die Sie bei Interesse nachlesen können.

Nachdem Sie IL-Code aus dem allgemeinen Code erstellt haben, möchten Sie diesen höchstwahrscheinlich ausführen. An dieser Stelle übernimmt die CLR und startet den Prozess der Just-In-Time-Kompilierung Ihres Codes aus der Zwischensprache in Computercode, der dann auf einer CPU ausgeführt werden kann. Auf diese Weise ist die CLR genau über den Status Ihres Codes informiert und kann ihn effektiv verwalten.

Intermediate Language wird auch als Common Intermediate Language (CIL) oder Zwischensprache bezeichnet.

Interoperabilität mit nicht verwaltetem Code

Natürlich erlaubt die CLR ein Überschreiten der Grenzen zwischen dem verwaltetem und dem nicht verwaltetem Bereich, und es gibt selbst in den -Klassenbibliotheken eine Menge Code, der diese Möglichkeit nutzt. Dies wird als Interoperabilität oder kurz Interop bezeichnet. Durch diese Möglichkeit können Sie beispielsweise eine nicht verwaltete Bibliothek paketieren und aufrufen. Allerdings müssen Sie bei dieser Vorgehensweise beachten, dass die eigentliche Verwaltung der Ausführung wieder beim nicht verwalteten Code liegt, sobald der Code die Grenzen der Runtime überschreitet, und dass die Ausführung daher denselben Einschränkungen unterliegt.

In ähnlicher Weise ist C# eine Sprache, die Ihnen die Verwendung nicht verwalteter Konstrukte (z. B. Zeiger) direkt im Code erlaubt, indem Sie den sogenannten unsicheren Kontext nutzen. Dieser kennzeichnet einen Teil des Codes, dessen Ausführung nicht von der CLR verwaltet wird.

Weitere Ressourcen