<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Portable_Executable</id>
	<title>Portable Executable - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Portable_Executable"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Portable_Executable&amp;action=history"/>
	<updated>2026-05-17T23:43:18Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Portable_Executable&amp;diff=278997&amp;oldid=prev</id>
		<title>93.229.172.205: /* Weblinks */ Why is 0x00400000 the default base address for an executable? by Raymond Chen</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Portable_Executable&amp;diff=278997&amp;oldid=prev"/>
		<updated>2024-03-27T17:29:10Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Weblinks: &lt;/span&gt; Why is 0x00400000 the default base address for an executable? by Raymond Chen&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;Portable Executable&amp;#039;&amp;#039;&amp;#039; beschreibt ein Binärformat [[Ausführbares Programm|ausführbarer Programme]], sogenannte &amp;#039;&amp;#039;&amp;#039;PE-Dateien&amp;#039;&amp;#039;&amp;#039;. Es ist das [[Dateiformat]], das bei [[Win32]]- und [[Win64]]-Systemen für ausführbare Dateien verwendet wird. Außerdem ist es das Format für ausführbare Dateien in [[Unified Extensible Firmware Interface|EFI]]-Umgebungen. Es basiert auf dem [[Common Object File Format|COFF]]-Binärformat.&amp;lt;ref&amp;gt;{{Internetquelle |url=https://www.betaarchive.com/wiki/index.php/Microsoft_KB_Archive/121460 |titel=Microsoft KB Archive/121460 - BetaArchive Wiki |abruf=2021-12-11}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Mögliche Dateiendungen sind zum Beispiel:&lt;br /&gt;
* .exe – &amp;#039;&amp;#039;executable&amp;#039;&amp;#039;, ein alleinstehendes [[Computerprogramm|Programm]] oder das Hauptmodul&lt;br /&gt;
* .dll – &amp;#039;&amp;#039;[[Dynamic Link Library]]&amp;#039;&amp;#039;&lt;br /&gt;
* .sys – &amp;#039;&amp;#039;system&amp;#039;&amp;#039;, grundlegende [[Systemsoftware]] mit besonderer Behandlung durch das Betriebssystem&lt;br /&gt;
* .drv – &amp;#039;&amp;#039;driver&amp;#039;&amp;#039;, ein [[Gerätetreiber|Treiber]]&lt;br /&gt;
* .scr – &amp;#039;&amp;#039;screensaver&amp;#039;&amp;#039;, ein [[Bildschirmschoner]]&lt;br /&gt;
* .cpl – &amp;#039;&amp;#039;control panel applet&amp;#039;&amp;#039;, ein Plugin der Windows-Systemsteuerung&lt;br /&gt;
* .ocx – &amp;#039;&amp;#039;activex control&amp;#039;&amp;#039;, ein [[ActiveX]]-Steuerelement&lt;br /&gt;
* .ax – ein [[DirectShow]]-Filter&lt;br /&gt;
* .efi – ein [[Extensible Firmware Interface|EFI]]-Modul&lt;br /&gt;
Außer der Erweiterung [[.exe]], die eine Datei als eigenständiges Programm identifiziert, ist das PE-Format nicht an eine Erweiterung gebunden. &lt;br /&gt;
Programmiertechnisch kann das System dazu gebracht werden, Code in jeder im PE-Format vorliegenden Datei auszuführen.&lt;br /&gt;
DLL-Dateien können beispielsweise Funktionen exportieren, die von anderen Programmen aufgerufen werden. Bei DRV- und SYS-Dateien handelt es sich in der Regel um Gerätetreiber, welche von [[Microsoft Windows|Windows]] verwendet werden, um die [[Hardware]] anzusteuern.&lt;br /&gt;
&lt;br /&gt;
Neben Windows verwendet auch [[ReactOS]] das PE-Dateiformat und ermöglicht so (zurzeit nur sehr beschränkt) die Ausführung von Windows-Programmen. Frühe Versionen von [[BeOS]] sowie [[SkyOS]] verwendeten ebenfalls das PE-Dateiformat für ihre ausführbaren Programme. Da sie aber eine andere [[Binärschnittstelle]] (ABI) verwendeten, waren sie nicht [[Binärkompatibilität|binärkompatibel]] zu Windows und beabsichtigten dies auch gar nicht. SkyOS verwendet inzwischen das verbreitete [[Executable and Linking Format|ELF]]-Format, welches zuvor mit dem Betriebssystem [[Linux]] populär wurde, da es dort das Standardformat für Binärprogramme ist.&lt;br /&gt;
&lt;br /&gt;
Windows-Dateien im PE-Format lassen sich unter Linux mit Hilfe von [[WINE]] und unter [[Disk Operating System|DOS]] teilweise mit Hilfe des [[HX DOS Extender]]s ausführen.&lt;br /&gt;
&lt;br /&gt;
== Aufbau ==&lt;br /&gt;
Jede PE-Datei beginnt mit dem aus DOS-Zeiten bekannten [[MZ-Datei|MZ-Header]]. Dieser dient hier in erster Linie dazu, ein [[EXE]]-Programm, das nicht für ein DOS-Betriebssystem bestimmt ist, mit einer Fehlermeldung (z. B. „This program cannot be run in DOS Mode“) zu beenden, falls versucht wird, es doch unter DOS zu starten. Am Anfang einer PE-Datei sind daher, wie bei jeder EXE-Datei von MS-DOS, die zwei Buchstaben „MZ“ zu finden, die Initialen von [[Mark Zbikowski]], dem Entwickler des DOS-Programmformats. Technisch gesehen handelt es sich bei dem Code, der die Fehlermeldung ausgibt, um ein vollständiges DOS-Programm, das entsprechend programmiert unter DOS auch andere Funktionen als eine Fehlermeldung haben kann.&lt;br /&gt;
&lt;br /&gt;
Das letzte Feld im DOS-Header verweist auf die Position des PE-Headers, der dann auch mit der ASCII-Kennung „PE“ und zwei Null-Bytes beginnt.&amp;lt;ref&amp;gt;{{Internetquelle |autor=Karl-Bridge-Microsoft |url=https://docs.microsoft.com/en-us/windows/win32/debug/pe-format |titel=PE Format - Win32 apps |sprache=en-us |abruf=2021-12-11}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Der eigentliche PE-Header besteht aus zwei Teilen, dem IMAGE_FILE_HEADER, der die Anzahl der Segmente, den erforderlichen CPU-Typ und weitere Flags enthält, sowie dem IMAGE_OPTIONAL_HEADER (der für lauffähige Programmdateien trotz des Namens nicht optional ist). Dieser enthält unter anderem die Größe der einzelnen Code- und Datensegmente in der Datei sowie weitere Angaben über die benötigten Ressourcen (Speicher, Betriebssystemversion).&lt;br /&gt;
&lt;br /&gt;
Nachfolgender [[Hexdump]] veranschaulicht den Beginn eines EXE-Programms für Windows (32 Bit). Die Leerzeile ist zur Verdeutlichung des Stub-Endes eingefügt. Danach beginnt ab Adresse 00000100h der PE-Header. Die DOS-Fehlermeldung der als Stub eingefügten, nur 256 [[Byte]] großen MZ-Datei lautet in diesem Fall „This program must be run under Win32“.&lt;br /&gt;
 00000000:   &amp;#039;&amp;#039;&amp;#039;4D 5A&amp;#039;&amp;#039;&amp;#039; 50 00 02 00 00 00 04 00 0F 00 FF FF 00 00    &amp;#039;&amp;#039;&amp;#039;MZ&amp;#039;&amp;#039;&amp;#039;P.............&lt;br /&gt;
 00000010:   B8 00 00 00 00 00 00 00 40 00 1A 00 00 00 00 00    ........@.......&lt;br /&gt;
 00000020:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 00000030:   00 00 00 00 00 00 00 00 00 00 00 00 &amp;#039;&amp;#039;&amp;#039;00 01 00 00&amp;#039;&amp;#039;&amp;#039;    ................&lt;br /&gt;
 00000040:   BA 10 00 0E 1F B4 09 CD 21 B8 01 4C CD 21 90 90    ........!..L.!..&lt;br /&gt;
 00000050:   54 68 69 73 20 70 72 6F 67 72 61 6D 20 6D 75 73    This program mus&lt;br /&gt;
 00000060:   74 20 62 65 20 72 75 6E 20 75 6E 64 65 72 20 57    t be run under W&lt;br /&gt;
 00000070:   69 6E 33 32 0D 0A 24 37 00 00 00 00 00 00 00 00    in32..$7........&lt;br /&gt;
 00000080:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 00000090:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000A0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000B0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000C0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000D0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000E0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 000000F0:   00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00    ................&lt;br /&gt;
 &lt;br /&gt;
 00000100:   &amp;#039;&amp;#039;&amp;#039;50 45 00 00&amp;#039;&amp;#039;&amp;#039; 4C 01 06 00 19 5E 42 2A 00 00 00 00    &amp;#039;&amp;#039;&amp;#039;PE..&amp;#039;&amp;#039;&amp;#039;L....^B*....&lt;br /&gt;
 00000110:   00 00 00 00 E0 00 8E 81 0B 01 02 19 00 38 01 00    .............8..&lt;br /&gt;
 00000120:   00 88 06 00 00 00 00 00 F0 45 01 00 00 10 00 00    .........E......&lt;br /&gt;
 ...&lt;br /&gt;
 ...&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://www.microsoft.com/whdc/system/platform/firmware/PECOFF.mspx Microsoft Portable Executable and Common Object File Format Specification] (englisch)&lt;br /&gt;
* Matt Pietrek:  [https://msdn.microsoft.com/en-us/library/ms809762.aspx Peering Inside the PE: A Tour of the Win32 Portable Executable File Format] (englisch)&lt;br /&gt;
* [http://www.iana.org/assignments/media-types/application/vnd.microsoft.portable-executable MIME Typ-Registrierung] (englisch)&lt;br /&gt;
* [http://www.deinmeister.de/w32asm5.htm Win32 Assembler Tutorial]&lt;br /&gt;
*[https://docs.microsoft.com/en-us/windows/win32/debug/pe-format Microsoft Docs PE Format Specification] (englisch)&lt;br /&gt;
*[https://devblogs.microsoft.com/oldnewthing/20141003-00/?p=43923 Why is 0x00400000 the default base address for an executable? by Raymond Chen] (englisch)&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Binärformat für ausführbare Programme, Bibliotheken und/oder Objektcode]]&lt;/div&gt;</summary>
		<author><name>93.229.172.205</name></author>
	</entry>
</feed>