Sammanfoga Grenar
Förståelse av sammanslagning av grenar
I Git är sammanfogning processen att integrera ändringar från en gren till en annan. Det vanligaste användningsområdet är att slå samman feature-grenar med main-grenen (t.ex. main eller master). Detta säkerställer att de senaste funktionerna och buggfixarna införlivas i huvudkodbasen.
Grundläggande arbetsflöde för sammanslagning
Visa först de två senaste commitarna.
Observera att du för närvarande befinner dig på grenen feature/new-feature.
Som du kan se ligger grenen master ett commit bakom.
Innan sammanslagning måste du byta till den gren där ändringarna ska integreras.
Byt till grenen master och visa de två senaste commiten på den:
Grenen master ligger faktiskt ett commit bakom feature-grenen.
För att slå ihop dem, använd kommandot git merge och ange vilken gren som ska slås ihop med den aktuella grenen.
Till exempel, för att slå ihop grenen feature/new-feature med master, kör:
Meddelandet som visas efter att kommandot har körts innehåller följande: Fast-forward, vilket anger att en fast-forward-sammanfogning har utförts.
Du kommer att undersöka de två typerna av sammanfogningar senare i detta kapitel. Innan dess, visa de två senaste commitarna:
Du är fortfarande på master-grenen, men den är nu uppdaterad med feature-grenen, där båda grenarna pekar på samma commit.
HEAD pekar fortfarande på master-grenen eftersom du befann dig på denna gren när sammanslagningen genomfördes.
Sammanfogningstyper
Det finns två typer av sammanfogningsoperationer i Git:
- Fast-forward-sammanfogning;
- Trevägssammanfogning.
Fast-forward-sammanfogning
Den sammanfogning du utförde är en fast-forward-sammanfogning, vilket anges i meddelandet. Denna typ uppstår när alla commit:ar från den aktuellt utcheckade grenen också finns i den gren som sammanfogas, vilket innebär att deras commit-historik inte har förgrenats.
Se följande illustration för förtydligande:
Vid denna typ av sammanfogning uppdateras pekaren för den utcheckade grenen helt enkelt till den senaste commit:en.
Trevägssammanfogning
Om grenarnas historik däremot har förgrenats, vilket innebär att nya commit:ar har gjorts separat på varje gren efter en viss gemensam commit, utförs en trevägssammanfogning.
Begreppet "trevägs" syftar på de tre versioner som är involverade i sammanfogningen:
- Versionen av den senaste gemensamma föregångaren (commit);
- Versionen av den senaste commit:en i den aktuella grenen (HEAD);
- Versionen av den senaste commit:en i den gren som sammanfogas.
Titta på följande illustration av denna typ av sammanfogning:
Så här fungerar en trevägs-sammanslagning:
- Git identifierar ändringarna som gjorts på varje gren efter den senaste gemensamma förfadern;
- Om varje gren har ändringar i olika filer eller olika delar av samma fil, kommer Git att automatiskt slå samman ändringarna genom att kombinera dem i den resulterande commiten;
- Annars uppstår en sammanslagningskonflikt.
Tack för dina kommentarer!
Fråga AI
Fråga AI
Fråga vad du vill eller prova någon av de föreslagna frågorna för att starta vårt samtal
Awesome!
Completion rate improved to 3.57
Sammanfoga Grenar
Svep för att visa menyn
Förståelse av sammanslagning av grenar
I Git är sammanfogning processen att integrera ändringar från en gren till en annan. Det vanligaste användningsområdet är att slå samman feature-grenar med main-grenen (t.ex. main eller master). Detta säkerställer att de senaste funktionerna och buggfixarna införlivas i huvudkodbasen.
Grundläggande arbetsflöde för sammanslagning
Visa först de två senaste commitarna.
Observera att du för närvarande befinner dig på grenen feature/new-feature.
Som du kan se ligger grenen master ett commit bakom.
Innan sammanslagning måste du byta till den gren där ändringarna ska integreras.
Byt till grenen master och visa de två senaste commiten på den:
Grenen master ligger faktiskt ett commit bakom feature-grenen.
För att slå ihop dem, använd kommandot git merge och ange vilken gren som ska slås ihop med den aktuella grenen.
Till exempel, för att slå ihop grenen feature/new-feature med master, kör:
Meddelandet som visas efter att kommandot har körts innehåller följande: Fast-forward, vilket anger att en fast-forward-sammanfogning har utförts.
Du kommer att undersöka de två typerna av sammanfogningar senare i detta kapitel. Innan dess, visa de två senaste commitarna:
Du är fortfarande på master-grenen, men den är nu uppdaterad med feature-grenen, där båda grenarna pekar på samma commit.
HEAD pekar fortfarande på master-grenen eftersom du befann dig på denna gren när sammanslagningen genomfördes.
Sammanfogningstyper
Det finns två typer av sammanfogningsoperationer i Git:
- Fast-forward-sammanfogning;
- Trevägssammanfogning.
Fast-forward-sammanfogning
Den sammanfogning du utförde är en fast-forward-sammanfogning, vilket anges i meddelandet. Denna typ uppstår när alla commit:ar från den aktuellt utcheckade grenen också finns i den gren som sammanfogas, vilket innebär att deras commit-historik inte har förgrenats.
Se följande illustration för förtydligande:
Vid denna typ av sammanfogning uppdateras pekaren för den utcheckade grenen helt enkelt till den senaste commit:en.
Trevägssammanfogning
Om grenarnas historik däremot har förgrenats, vilket innebär att nya commit:ar har gjorts separat på varje gren efter en viss gemensam commit, utförs en trevägssammanfogning.
Begreppet "trevägs" syftar på de tre versioner som är involverade i sammanfogningen:
- Versionen av den senaste gemensamma föregångaren (commit);
- Versionen av den senaste commit:en i den aktuella grenen (HEAD);
- Versionen av den senaste commit:en i den gren som sammanfogas.
Titta på följande illustration av denna typ av sammanfogning:
Så här fungerar en trevägs-sammanslagning:
- Git identifierar ändringarna som gjorts på varje gren efter den senaste gemensamma förfadern;
- Om varje gren har ändringar i olika filer eller olika delar av samma fil, kommer Git att automatiskt slå samman ändringarna genom att kombinera dem i den resulterande commiten;
- Annars uppstår en sammanslagningskonflikt.
Tack för dina kommentarer!