Leistungen
Leistungen
Überblick
Leistungsangebot
Kernkompetenzen
Schulungsthemen
In-House-Schulungen
Offene .NET-Seminare
Offene WPS-Seminare
Beratung
Support
.NET/Visual Studio
TFS/ALM/Scrum
Webprogrammierung
PowerShell
Konditionen
Anfrage/Kontakt
In-House-Schulungen
In-House-Schulungen
Überblick
Themen
Schulungskonfigurator
Konzepte
.NET/Visual Studio
C#
VB.NET
ASP.NET
TFS/ALM/Scrum
PowerShell
Konferenzvortraege
Referenzkunden
Trainerprofile
Konditionen
Anfrage
Offene Schulungen
Offene Schulungen
Überblick .NET-Seminare
.NET/C#-Basisseminar
WPF (Desktop)
ASP.NET/AJAX (Web)
WCF/WF (SOA)
ADO.NET/EF (Data)
Windows PowerShell
.NET
.NET
Startseite
Beratung/Training
Offene .NET-Seminare
Einführung
Lexikon
Artikel
Bücher
Klassenreferenz
Programmiersprachen
Entwicklerwerkzeuge
Softwarekomponenten
World Wide Wings Demo
Codebeispiele
Scripting
ASP.NET
.NET 2.0
.NET 3.0/3.5
.NET 4.0
Community
Forum
Kommerzielle Leistungen
ASP.NET
ASP.NET
Startseite
Lexikon
Sicherheit
Konfiguration
Global.asax
Tracing
Mehr zu ASP.NET 1.x
Mehr zu ASP.NET 2.0
Klassenreferenz
Programmiersprachen
Entwicklerwerkzeuge
Softwarekomponenten
PowerShell
PowerShell
Überblick
Beratung
In-House-Schulungen
Öffentliche Schulungen
Codebeispiele
Commandlet Extensions
Windows Scripting
Windows Scripting
Startseite
Lexikon
FAQ
Buecher
Architektur
Skriptsprachen
Scripting-Hosts
Scripting-Komponenten
COM/DCOM/COM+
ADSI
WMI
WMI-Klassenreferenz
Scripting-Tools
WSH-Editoren
Codebeispiele
ASP.NET
.NET-Scripting
Forum
Links
Kommerzielle Leistungen
Windows Server
Windows Server
Startseite
Lexikon
Forum
Service
Service
Website-FAQ
Anmeldung/Login
Leser-Registrierung
Gast-Registrierung
Nachrichten/RSS
Newsletter
Foren
Weblog Deutsch
Lexikon
Downloads
Support
Kontakt
Literaturtipps
Publikationen
Publikationen
Redaktionsbüro
Bücher
Fachartikel
Leser-Portal
Autoren gesucht!
Rezensionen
Über uns
Über uns
Holger Schwichtenberg
Team
Referenzkunden
Kundenaussagen
Referenzprojekte
Partner
Site Map
Tag Cloud
Impressum
Rechtliches
AGB

Erklärung des Begriffs: Microsoft Intermediate Language (MSIL)
Was ist Microsoft Intermediate Language (MSIL)?

Zurück zur Stichwortliste



Begriff Microsoft Intermediate Language
Abkürzung MSIL
Synonyme/Aliase

Erläuterung des Begriffs Microsoft Intermediate Language

Microsoft Intermediate Language (MSIL) ist die in .NET verwendete Zwischensprache.

Sowohl die Programmiersprache Java als auch das .NET Framework basieren auf dem Konzept Write Once Run Anywhere (WORA), d. h., eine einmal entwickelte und kompilierte Anwendung kann auf verschiedenen Betriebssystemen ablaufen. Das .NET Framework arbeitet – genau wie Java – mit einem Intermediationskonzept auf Basis einer Zwischensprache und einer virtuellen Maschine (WM). Ein Compiler einer .NET-Hochsprache erzeugt also keinen prozessorspezifischen Maschinencode, sondern einen plattformunabhängigen Zwischencode. Dieser Zwischencode wird Microsoft Intermediate Language (MSIL) oder – im ECMA- und ISO-Standard – Common Intermediate Language (CIL) genannt. Code in MSIL wird auch als verwalteter Code (Managed Code) bezeichnet. Im Gegensatz dazu wird prozessorspezifischer Maschinencode als nicht-verwalteter (Unmanaged Code) oder Native Code bezeichnet.

Erst zur Laufzeit wird der MSIL-Code dann in einen prozessorspezifischen Maschinencode (Native Code) umgewandelt. MSIL-Code wird nicht interpretiert, sondern von einem sogenannten Just-in-Time-Compiler stückchenweise umgewandelt und dann ausgeführt. Dabei berücksichtigt der Just-in-Time-Compiler prozes-
sorspezifische Optimierungsmöglichkeiten. Dadurch, dass nicht interpretiert, sondern vor der Ausführung kompiliert wird und der Just-in-Time-Compiler sehr schnell arbeitet, ist der Leistungsverlust durch die Intermediation sehr gering. Im Zweifel gibt es auch die Möglichkeit, das Ergebnis der Kompilierung von MSIL zu Maschinencode zu speichern und später auszuführen. Dies nennt man Native Image. Ein Native Image ist jedoch nicht mehr plattformunabhängig. Es ist nicht verboten, dass Sprach-Compiler wahlweise auch direkt Native Code erzeugen, der nicht unter der Kontrolle der .NET-Laufzeitumgebung abläuft.

Der Just-in-Time-Compiler (JIT-Compiler oder JITter) ist Teil der .NET-Laufzeitumgebung, die Common Language Runtime (CLR) genannt wird. Das Intermediationskonzept ist die Basis für die Plattformunabhängigkeit der Anwendungen. Managed Code kann auf jedem Betriebssystem ausgeführt werden, für das eine Implementierung der Common Language Runtime verfügbar ist.

Natürlich ist Managed Code langsamer als Native Code, wobei der Geschwindigkeitsunterschied sehr viel geringer ist, als man vermutet. Wenn jedoch die optimale Geschwindigkeit notwendig ist, besteht die Möglichkeit, eine Managed-Code-Datei einmalig in eine Native-Code-Datei umzuwandeln. Dazu dient das Werkzeug ngen.exe. Der Vorgang wird als Pre-Jitting bezeichnet. Das Resultat von ngen.exe nennt man ein Native Image. Ngen.exe wurde in .NET 2.0 stark vereinfacht (z. B. werden nun alle referenzierten Kompo-nenten automatisch mitübersetzt).

Grundsätzlich kann zwar ein Native Image bereits während der Entwicklung erzeugt werden; aufgrund der plattformspezifischen Übersetzung bietet es sich jedoch an, das Native Image erst bei der Installation einer .NET-Anwendung zu erzeugen (Install Time Compilation). Das Native Image ist spezifisch für eine bestimm-te Version der .NET-Laufzeitumgebung. Auch benötigen DOS- und NT-basierte Windows-Systeme verschie-dene Native Images. Eine .NET-Anwendung, die in einem Native Image gespeichert ist, braucht ebenfalls die .NET-Laufzeitumgebung, um ausgeführt werden zu können.

Querverweise zu anderen Begriffen im Lexikon


siehe Intermediation

Common Intermediate Language
Write Once Run Anywhere
Common Language Runtime
Just-in-Time-Compiler
Verwalteter Code
Intermediation
Unmanaged Code
Managed Code
Native Image
Native Code
Compiler
JITting
Java