bg_image
header

Merge Konflik

Ein Merge-Konflikt tritt in Versionskontrollsystemen wie Git auf, wenn zwei verschiedene Änderungen an derselben Datei nicht automatisch zusammengeführt (gemerged) werden können. Das passiert, wenn mehrere Entwickler gleichzeitig an denselben Teilen einer Datei arbeiten und deren Änderungen kollidieren.

Beispiel eines Merge-Konflikts:

Stellen Sie sich vor, zwei Entwickler arbeiten an derselben Datei in einem Projekt:

  1. Entwickler A ändert Zeile 10 der Datei und fügt diese Änderung in den Hauptzweig (z.B. main) ein.
  2. Entwickler B ändert ebenfalls Zeile 10, aber in einem separaten Zweig (z.B. feature-branch).

Wenn Entwickler B versucht, seinen Zweig (feature-branch) mit dem Hauptzweig (main) zusammenzuführen, erkennt Git, dass dieselbe Zeile in beiden Zweigen geändert wurde, und kann nicht automatisch entscheiden, welche Änderung beibehalten werden soll. Dies führt zu einem Merge-Konflikt.

Wie wird ein Merge-Konflikt gelöst?

  • Git markiert die betroffenen Stellen in der Datei und zeigt die konkurrierenden Änderungen an.
  • Der Entwickler muss dann manuell entscheiden, welche der Änderungen beibehalten werden soll oder ob eine Kombination aus beiden Änderungen sinnvoll ist.
  • Nach der Behebung des Konflikts kann die Datei erneut gemerged und der Konflikt gelöst werden.

Typische Konflikt-Markierungen:

In der Datei sieht ein Konflikt oft so aus:

<<<<<<< HEAD
Änderung von Entwickler A
=======
Änderung von Entwickler B
>>>>>>> feature-branch

Hier muss der Entwickler den Konflikt manuell auflösen und die Datei entsprechend anpassen.