Git中合并与变基的区别
Git中合并与变基的区别
data:image/s3,"s3://crabby-images/4f9eb/4f9eb3948229f61096742c69e0faac2e65e10482" alt="从 master 拉取一个 feature 分支"
data:image/s3,"s3://crabby-images/8cb28/8cb2865694eda42081577eda24208d7365282838" alt="分支冲突"
在 feature
分支进行了两次提交,此时其它人也进行了两次提交,并且合并到了 master
分支,此时是无法push到远程仓库的,需要进行分支合并。
Merge
将两个分支合并,将分支的历史记录合并在一起。并创建一个新的合并提交 merge commit。
data:image/s3,"s3://crabby-images/52ce4/52ce4a7cf35bd7f142e4d825c23d5f2c5b375510" alt="git merge"
Rebase
将一个分支上的提交应用到另一个分支的基础上,重新排列提交历史。不会创建新的合并提交,而是将提交重新放置,使分支历史看起来像是线性的一条直线。
data:image/s3,"s3://crabby-images/270a5/270a50f78f2167b35f4bbf8194eca0cb1fbd09d1" alt="git rebase"
示例
将
develop
分支的最新变更应用到release
分支上。
# 切换到 release 分支上
git rebase develop
# Successfully rebased and updated refs/heads/release.
最后更新于