赞
踩
Git的分支(Branch)是Git版本控制系统中的一个核心概念,它允许你创建代码的多个并行版本,从而使得团队成员可以在不影响主开发线路的情况下进行功能开发、错误修复或实验性尝试。以下是关于Git分支的一些关键点:
master
或main
)的情况下工作,这样就可以安全地进行新功能的添加或错误的修复。git branch
查看当前所处分支:
git branch xx分支名
创建一个新分支:
git checkout xx分支名
切换到目标分支:git checkout -b xx分支名
创建并切换分支(相当于合并了上两条命令):git branch -d xx分支名
删除目标分支:注意:不能删除当前的分支
在Git中,pull
、fetch
和 merge
是三个非常重要的命令,它们帮助你与远程仓库同步代码。下面是这三个命令的解释和用法:
git fetch
git fetch
命令用于从远程仓库下载最新的分支和标签数据到本地仓库,但不会自动合并到你当前的工作分支。这个过程不会改变你当前的工作副本,只是让你能够查看远程仓库中的最新状态。
命令格式如下:
git fetch [remote]
其中,[remote]
是你想要获取更新的远程仓库名称,默认是 origin
。
git merge
git merge
命令用于将一个或多个分支的修改合并到当前分支。当你已经通过 git fetch
获取了远程分支的最新变化,或者当你想要合并本地的一个分支到当前分支时,就会用到这个命令。
命令格式:
git merge [branch]
这里的 [branch]
是你想要合并进来的分支名。
git pull
git pull
是一个复合命令,它实际上执行了 git fetch
和随后的 git merge
操作。也就是说,git pull
不仅会从远程仓库获取最新的数据,还会自动尝试将获取到的分支合并到你当前所在的本地分支上。
命令格式:
git pull [remote] [branch]
如果不指定 [branch]
,默认会尝试合并远程分支到当前分支。同样,如果没有指定 [remote]
,则默认为 origin
。
当执行 merge
命令进行合并时,Git具备一定的智能自动化处理能力:如果一个分支仅修改了文件A,而另一个分支独立地修改了文件B,Git能够无缝整合这些更改,自动完成合并过程——即最终的代码既包含了对A文件的修改也包含了对B文件的修改。同样地,若两个分支虽然都修改了同一个文件,但涉及的是文件中互不重叠的部分,比如一个改动发生在第一行,另一个则在第二行,Git同样能巧妙地自动合并这些非冲突性修改。
然而,当两个分支修改了同一文件的相同部分时,merge
操作就会遇到挑战,这时Git的自动合并算法无法确定应该采用哪个分支的修改。这种情况下,Git会标记这些区域为“冲突”(Conflict)。遭遇冲突时,Git会暂停合并过程,并在冲突文件中明确标记出争议区域,同时留下标记指示哪些是来自不同分支的修改内容。此时,就需要开发者介入,手动检查这些冲突,决定如何解决分歧,保留或结合双方的修改,以达到期望的合并结果。
可以看到,Git 虽然没有帮你完成自动 merge,但它对文件还是做了一些工作:它把两个分支冲突的内容放在了一起,并用符号标记出了它们的边界以及它们的出处。上面图中表示,HEAD 中的内容是 code 222
,而 refs/remotes/origin/main 中的内容则是 code 111
。这两个改动 Git 不知道应该怎样合并,于是把它们放在一起,由你来决定。假设你决定保留 HEAD 的修改,那么只要删除掉 refs/remotes/origin/main 的修改,再把 Git 添加的那三行 <<< === >>> 辅助文字也删掉,保存文件退出,所谓的「解决掉冲突」就完成了。
执行git merge --abort
让Git 仓库回到 merge 前的状态。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。