<?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=Diff</id>
	<title>Diff - 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=Diff"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Diff&amp;action=history"/>
	<updated>2026-05-19T07:00:38Z</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=Diff&amp;diff=272516&amp;oldid=prev</id>
		<title>imported&gt;Jesi: /* Geschichte */ lf</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Diff&amp;diff=272516&amp;oldid=prev"/>
		<updated>2026-04-03T14:23:03Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Geschichte: &lt;/span&gt; lf&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{SEITENTITEL:diff}}&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;diff&amp;#039;&amp;#039;&amp;#039; (kurz zu [[amerikanisches Englisch|amerikanisch]]: &amp;#039;&amp;#039;{{lang|en-US|difference|de=Differenz}}&amp;#039;&amp;#039;) ist ein [[Unix]]-Programm, das die &amp;#039;&amp;#039;&amp;#039;Unterschiede&amp;#039;&amp;#039;&amp;#039; zwischen zwei [[Textdatei]]en zeilen- bzw. abschnittweise einander gegenüberstellt.&lt;br /&gt;
&lt;br /&gt;
== Grundlagen ==&lt;br /&gt;
diff ist eine grundlegende [[Kommandozeile]]nfunktion eines Unixsystems. Eine weite Palette von Computerprogrammen macht sich dies zunutze. Die Ausgabe des Programms geschieht in Textform und wird oft ebenfalls als &amp;#039;&amp;#039;diff&amp;#039;&amp;#039; bezeichnet ([[Dateiendung]] &amp;lt;code&amp;gt;.diff&amp;lt;/code&amp;gt;). Das Ausgabeformat ermöglicht eine maschinelle Verarbeitung.&lt;br /&gt;
&lt;br /&gt;
Anwendungen in der [[Versionsverwaltung]] sind vielfältig: So kann die Ausgabe von diff zum Beispiel als Eingabe für das Unix-Programm [[Patch (Unix)|patch]] verwendet werden, um die Änderungen, die diff festgestellt hat, an einer anderen Textdatei auszuführen. Zudem gibt es eine Reihe von Programmen, welche die von diff ausgegebenen Unterschiede in übersichtlicher graphischer Form darstellen. Außerdem bildet diff die Grundlage aller &amp;#039;&amp;#039;[[Merge]]&amp;#039;&amp;#039;-Funktionen.&lt;br /&gt;
&lt;br /&gt;
== Programmfunktion ==&lt;br /&gt;
Die ersten Versionen des Programms wurden programmiert, um Textdateien zu vergleichen. Seit 1980 unterstützt diff aber auch [[Binärdatei]]en.&lt;br /&gt;
&lt;br /&gt;
=== Aufruf ===&lt;br /&gt;
diff wird auf der [[Kommandozeile]] mit den Namen von zwei Textdateien als [[Parameter (Informatik)|Parameter]] ausgeführt:&lt;br /&gt;
&lt;br /&gt;
 $ diff telefonliste2007.txt telefonliste2008.txt&lt;br /&gt;
&lt;br /&gt;
Die beiden Textdateien werden zeilenweise verglichen, das heißt, auch wenn sich eine Zeile in den beiden Dateien nur in einem einzelnen Zeichen unterscheidet, interpretiert diff das als eine gelöschte und eine neu eingefügte Zeile.&lt;br /&gt;
&lt;br /&gt;
=== Ausgabe ===&lt;br /&gt;
Die folgenden zwei Dateien werden mit diff verglichen.&lt;br /&gt;
&lt;br /&gt;
{|&lt;br /&gt;
|- style=&amp;quot;vertical-align:top&amp;quot;&lt;br /&gt;
| telefonliste2007.txt:&lt;br /&gt;
 Mayer, Susanne, Lager, -212&lt;br /&gt;
 Schmid, Carola, Geschäftsleitung, -435&lt;br /&gt;
 Schmidt, Eberhard, Vertrieb, -479&lt;br /&gt;
 Schmitt, Marie, Labor, -804&lt;br /&gt;
| telefonliste2008.txt:&lt;br /&gt;
 Mayer, Susanne, Lager, -212&lt;br /&gt;
 Schmid, Carola, Geschäftsleitung, -435&lt;br /&gt;
 Schmitt, Marie, Labor, -804&lt;br /&gt;
 Waldmann, Ernst, Labor, -805&lt;br /&gt;
 Zundel, Walter, Vertrieb, -476&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Die Ausgabe von diff sieht dann so aus:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;diff&amp;quot;&amp;gt;&lt;br /&gt;
3d2&lt;br /&gt;
&amp;lt; Schmidt, Eberhard, Vertrieb, -479&lt;br /&gt;
4a4,5&lt;br /&gt;
&amp;gt; Waldmann, Ernst, Labor, -805&lt;br /&gt;
&amp;gt; Zundel, Walter, Vertrieb, -476&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Es gibt verschiedene Ausgabeformate. Das obige Beispiel entspricht der Normal-Ausgabe (&amp;#039;&amp;#039;normal diff&amp;#039;&amp;#039;) ohne weitere Optionen. Die Zeilen, die mit einer spitzen, öffnenden Klammer beginnen, sind nur in der ersten Datei vorhanden, diejenigen, die mit einer spitzen, schließenden Klammer beginnen, sind nur in der zweiten Datei vorhanden. Zeilen, die in beiden Dateien gleich sind, werden nicht ausgegeben. Die einzelnen Blöcke werden durch sogenannte &amp;#039;&amp;#039;change commands&amp;#039;&amp;#039; („Änderungsbefehle“) getrennt, die angeben, welche Aktion (Zeilen hinzufügen – &amp;#039;&amp;#039;a&amp;#039;&amp;#039;, ändern – &amp;#039;&amp;#039;c&amp;#039;&amp;#039; oder entfernen – &amp;#039;&amp;#039;d&amp;#039;&amp;#039;) in welchen Zeilen ausgeführt werden soll.&amp;lt;ref&amp;gt;{{Internetquelle |url=https://www.gnu.org/software/diffutils/manual/html_node/Detailed-Normal.html |titel=Comparing and Merging Files&amp;amp;nbsp;– Detailed Description of Normal Format |werk=GNU Diffutils Manual |abruf=2009-02-17}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Das sogenannte &amp;#039;&amp;#039;vereinheitlichte Format&amp;#039;&amp;#039; (&amp;#039;&amp;#039;unified diff&amp;#039;&amp;#039;) erhält man durch die Option &amp;#039;&amp;#039;-u&amp;#039;&amp;#039;. Dabei wird jede Zeile, die nur in der ersten Datei vorkommt, mit einem Minuszeichen gekennzeichnet, und jede Zeile, die nur in der zweiten Datei vorkommt, mit einem Pluszeichen. Den beiden Dateien gemeinsame Zeilen werden durch ein Leerzeichen gekennzeichnet.&lt;br /&gt;
&lt;br /&gt;
Gewöhnlich werden dabei nicht alle Zeilen ausgegeben, sondern nur Blöcke von Zeilen, die sich in der Nähe eines Unterschiedes befinden. Am Anfang der Ausgabe stehen zwei Zeilen, die mit drei Minuszeichen respektive drei Pluszeichen gekennzeichnet werden. Sie zeigen die Dateien, auf die sich das diff bezieht. Jeder Block wird mit einer Zeile eingeleitet, die von [[@|At-Zeichen (@)]] umgeben ist. Diese zeigt an, in welchen Zeilen der entsprechende Block in beiden Dateien beginnt und, durch ein Komma getrennt, wie lang er in der jeweiligen Datei ist.&lt;br /&gt;
&lt;br /&gt;
Ausgabe des oberen Beispiels im unified-diff-Format:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;diff&amp;quot;&amp;gt;&lt;br /&gt;
--- telefonliste2007.txt    2007-12-28 13:12:34.000000000 +0100&lt;br /&gt;
+++ telefonliste2008.txt    2008-07-28 14:16:26.000000000 +0100&lt;br /&gt;
@@ -1,4 +1,5 @@&lt;br /&gt;
 Mayer, Susanne, Lager, -212&lt;br /&gt;
 Schmid, Carola, Geschäftsleitung, -435&lt;br /&gt;
-Schmidt, Eberhard, Vertrieb, -479&lt;br /&gt;
 Schmitt, Marie, Labor, -804&lt;br /&gt;
+Waldmann, Ernst, Labor, -805&lt;br /&gt;
+Zundel, Walter, Vertrieb, -476&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Geschichte ==&lt;br /&gt;
Das diff-Programm wurde in den frühen 1970er Jahren auf dem [[Unix]]-[[Betriebssystem]] von [[AT&amp;amp;T]] [[Bell Labs]] in Murray Hill, New Jersey, USA entwickelt. Die endgültige Version, die zu diesem sehr frühen Unix-System gehörte, wurde vollständig von [[Douglas McIlroy]] geschrieben. Diese Untersuchungen wurden 1976 in einem Dokument veröffentlicht, das von [[James W. Hunt]] mitverfasst wurde, welcher auch eine der anfänglichen Versionen von diff geschrieben hatte.&lt;br /&gt;
&lt;br /&gt;
McIlroys Arbeit wurde beeinflusst von [[Steve Johnson (Programmierer)|Steve Johnsons]] Vergleichs-Programm auf [[GECOS (Betriebssystem)|GECOS]] und [[Mike Lesk]]s &amp;#039;&amp;#039;proof&amp;#039;&amp;#039;-Programm, welches wie diff auch auf [[Unix]] entstanden ist. Proof produzierte Zeile-für-Zeile-Änderungen wie diff und verwendete dafür spitze Klammern („&amp;gt;“ und „&amp;lt;“), um Zeilen-Einfügungen und Zeilen-Entfernungen in der Ausgabe des Programms darzustellen. Die [[Heuristik|heuristische]] Methode, die diese Programme verwendeten, galt als unzuverlässig. Die potentielle Brauchbarkeit eines diff-Tools inspirierte McIlroy, ein neues, robusteres Programm zu entwickeln, welches viele Anwendungsmöglichkeiten hatte, aber trotzdem eine gute Performance in den Prozessor- und Speicher-Limits der [[PDP-11]]-[[Hardware]] lieferte. Sein Erfolg war ein Ergebnis der Zusammenarbeit mit den Leuten von Bell Labs, inklusive [[Alfred V. Aho]], [[Elliot N. Pinson]], [[Jeffrey Ullman]] und [[Harold S. Stone]].&lt;br /&gt;
&lt;br /&gt;
== Freie Softwareimplementierungen ==&lt;br /&gt;
[[Datei:Kompare.png|mini|Das grafische diff-Werkzeug &amp;#039;&amp;#039;Kompare&amp;#039;&amp;#039;]]&lt;br /&gt;
&lt;br /&gt;
Das [[GNU-Projekt]] stellt eine [[Implementierung#Softwaretechnik|Implementierung]] von diff (und diff3, welches drei Dateien vergleicht) im [[Programmpaket|Paket]] zur Verfügung.&lt;br /&gt;
&lt;br /&gt;
Etliche Tools, die auf verschiedenen Plattformen laufen, basieren auf der diffutils-Engine des GNU-Projektes und stellen ein graphisches [[Frontend]] für dieselben Informationen dar. Einige dieser Programme können Dateien auch bearbeiten und [[Merge|mergen]].&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Kompare]]&amp;amp;nbsp;– eine graphische Oberfläche für diff&lt;br /&gt;
* [[meld]]&amp;amp;nbsp;– sehr umfassende graphische Oberfläche für diff&lt;br /&gt;
* [[WinMerge]]&amp;amp;nbsp;– ein Open-Source-Diff für Windows&lt;br /&gt;
* [[Patch (Unix)|patch]]&amp;amp;nbsp;– das Gegenstück zu diff, mit dem Dateien anhand ihrer Unterschiede rekonstruiert werden&lt;br /&gt;
* [[Delta-Kodierung]]&amp;amp;nbsp;– ein Datenkompressionsverfahren, bei dem bei ähnlichen Dateien nur die Unterschiede zur Ausgangsdatei gespeichert werden, beispielsweise bei [[Versionsverwaltung]]en&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* {{Literatur |Autor=James W. Hunt, M. Douglas McIlroy |Titel=An Algorithm for Differential File Comparison |Sammelwerk=Computing Science Technical Report |Nummer=41 |Verlag=Bell Laboratories |Datum=1976-06 |Sprache=en}}&lt;br /&gt;
* {{Literatur |Autor=David MacKenzie, Paul Eggert, Richard Stallman |Titel=Comparing and Merging Files with GNU Diff and Patch |Datum=2002 |ISBN=0-9541617-5-0 |Sprache=en}}&lt;br /&gt;
* {{Literatur |Autor=E. Myers |Titel=An O(ND) Difference Algorithm and Its Variations |Sammelwerk=Algorithmica |Band=1 |Nummer=2 |Datum=1986 |Seiten=251–266 |Sprache=en |Online=[https://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.4.6927 CiteSeerX]}}&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
&lt;br /&gt;
{{Commonscat|File comparison}}&lt;br /&gt;
* [[Manpage]]s:&lt;br /&gt;
** {{man||diff|posix|compare two files}}&lt;br /&gt;
** {{man|1|diff|gnu|Dateien zeilenweise vergleichen}}&lt;br /&gt;
** {{man|1|diff|bsd|differential file and directory comparator}}&lt;br /&gt;
* {{dmoz|/Computers/Software/File_Management/File_Comparison/|Diff}}&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Unix-Software]]&lt;br /&gt;
[[Kategorie:Programmierwerkzeug]]&lt;br /&gt;
[[Kategorie:Versionsverwaltung]]&lt;br /&gt;
[[Kategorie:GNU-Paket]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Jesi</name></author>
	</entry>
</feed>