Git分支操作命令及团队协作

简介: 版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。

前言


版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。

下面以一个图形象的表示分支的概念。


一、分支相关命令



1、查看分支(git branch -v)


git branch -v


2、创建分支(git branch xx)


这里创建一个名为 hot-fix 的分支

git branch -v
git branch hot-fix
git branch -v


3、切换分支(git checkout xx)


1、切换到 hot-fix 分支

git checkout hot-fix
git branch -v

可以看到 hot-fix 分支前有个*,代表当前所处的分支

2、在 hot-fix 分支修改文件后查看状态,此时工作区存在未提交的hello.txt。需要重复添加暂存区-提交本地库的过程

tips:git checkout - //可以表示切换到上一个分支

把 hot-fix 做的改动添加到暂存区,并提交本地库形成历史版本及查看版本信息

git add hello.txt
git status
git commit -m "hot-fix first commit" hello.txt
git reflog

.git中的HEAD文件


4、合并分支(git merge xx)


①、正常合并

要转到想要合并到的分支上,git merge 要合并的分支

git checkout master
git reflog
git merge hot-fix
cat hello.txtv

master 分支的 hello.txt 成功修改了


②、冲突合并


问:什么时候会遇到合并冲突?

答:合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。Git 无法替我们决定使用哪一个。必须人为决定新代码内容。


1) 复现冲突:

在 master 分支:

vim hello.txt 
git add hello.txt
git commit -m "master test" hello.txt

在 hello.txt 倒数第二行新增 master test

在 git checkout hot-fix 分支:

git checkout hot-fix
vim hello.txt
git add hello.txt
git commit -m "hot-fix test" hello.txt

在 hello.txt 倒数第一行新增 hot-fix test

接下来依次执行下述指令:

git checkout master
git merge hot-fix
git status

根据报错可以看到由于两个分支的文件均被修改,导致合入失败,目前显示正在合并(master | MERGING)。

vim hello.txt

<<<<和====之间是当前分支代码

====和>>>>之间是合并的代码

明显看到这两处代码都做了修改,那么 git 就不知道要保留哪个部分

2) 解决办法:

手动合并代码

vim hello.txt

删除多余的内容,保留如下信息:

git status
git add hello.txt
git commit -m "merge test" 

注意:此时只能用git commit -m "merge test" 而不可以用 git commit -m "merge test" hello.txt,否则会报错如下错误

MERGING状态已不存在了,此时代码合并成功。

cat hello.txt


二、团队协作


需要用到代码托管中心,把代码推送到远程服务器

push 将代码上传到远程库

clone 将代码复制到本地

pull 将代码拉取到本地(pull 是本地已有文件,clone是本地无源代码)

fork 将代码从其他团队的远程库复制到自己的远程库

1、团队内协作



2、跨团队协作


fork 将代码从其他团队的远程库复制到自己的远程库,可以从自己的远程库clone。修改完成后push到自己的远程库。之后发送pull request向其他团队的远程库,经审核后即可使用merge合并


目录
相关文章
|
9月前
|
存储 安全 开发工具
深度解决 Git “fatal: refusing to merge unrelated histories” 错误解析什么是历史分支优雅草卓伊凡
深度解决 Git “fatal: refusing to merge unrelated histories” 错误解析什么是历史分支优雅草卓伊凡
782 4
深度解决 Git “fatal: refusing to merge unrelated histories” 错误解析什么是历史分支优雅草卓伊凡
|
6月前
|
开发工具 git
Git版本控制工具合并分支merge命令操作流程
通过以上步聚焦于技术性和操作层面指南(guidance), 可以有效管理项目版本控制(version control), 并促进团队协作(collaboration).
1462 15
|
9月前
|
安全 开发工具 git
git的常用操作命令
git的常用操作命令
555 57
|
7月前
|
存储 缓存 开发工具
Git stash命令的详细使用说明及案例分析。
通过上述案例,我们看到stash命令能够在不丢失进度的情况下,帮助开发者临时切换开发上下文,这在处理多个任务或紧急bug时特别有用。正确使用Git stash可以大大提高开发的灵活性和效率。
2233 0
|
开发工具 git 开发者
vscode+git解决远程分支合并冲突
通过这些详细步骤,您可以掌握如何使用VSCode和Git高效地解决远程分支合并冲突,提高开发效率和代码质量。希望这些内容对您的学习和工作有所帮助。
2983 86
|
12月前
|
人工智能 前端开发 Java
用git rebase命令合并开发阶段中多条commit提交记录
通过 `git rebase`,可以合并多个提交记录,使开发历史更简洁清晰。操作分为 6 步:查看提交历史 (`git log --oneline`)、设置需合并的提交数 (`git rebase -i HEAD~N`)、修改动作标识为 `s`(squash)、保存退出编辑、调整提交信息、强制推送至远程仓库 (`git push -f`)。此方法适合清理本地无关提交,但若有团队协作或冲突风险,需谨慎使用以避免问题。
2050 60
|
10月前
|
存储 项目管理 开发工具
Git常用命令及操作技巧
以上是Git的常用命令及操作技巧,尽管看起来有些繁琐,但实际上只要花费一些时间进行实践,您将很快熟练掌握。随着使用熟练度的提高,您会发现Git对项目管理和协同工作的强大帮助。
236 20
|
11月前
|
Linux 开发工具 git
版本控制工具:Git的安装和基本命令使用指南。
结束这段探险,掌握了Git你就等于掌握了一个宝藏,随时可以瞥见你的编程历程,轻松面对日后的挑战。Git,无疑是编程者的强大武器,开始你的Git探险之旅吧!
413 28
|
网络安全 开发工具 git
mac git clone命令提示git@gitee.com: Permission denied (publickey).问题修复
mac git clone命令拉取gitee上项目代码时提示密钥问题
1096 19
|
Java 网络安全 开发工具
Git进阶笔记系列(01)Git核心架构原理 | 常用命令实战集合
通过本文,读者可以深入了解Git的核心概念和实际操作技巧,提升版本管理能力。