相关技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > 相关技巧 > Git单分支与多分支协作

Git单分支与多分支的协作流程

作者:Explore

本文介绍了Git的基本用法,包括配置用户名和邮箱、clone和it两种初始化方式,接着详细讲解了两种分支协作场景的操作流程和注意事项;最后总结了常见问题及解决方法,需要的朋友可以参考下

一、先理解 Git 在做什么

一句话版本:Git 是一个版本管理工具,用来记录代码的每次变化。

二、第一次使用 Git,要先做的两件事

1)配置用户名和邮箱

git config --global user.name "你的名字"
git config --global user.email "你的邮箱"

它们会写进提交记录里,方便团队追踪修改来源。

2)查看配置是否生效

git config --list

三、两种开始方式:clone和init

方式 A:拉取远程已有项目

git clone <仓库地址>

例如:

git clone https://github.com/your-org/your-repo.git

方式 B:本地新项目

git init

在当前目录初始化一个 Git 仓库。

四、场景一:单分支协作(直接在团队分支上开发)

这个场景常见于小团队或内部项目:大家都在同一个长期分支上协作(例如 dev)。

目标

拿到仓库,拉最新代码,完成一个小需求并提交。

推荐流程

第 1 步:先查看当前有哪些分支

git branch -a

第 2 步:切换到团队分支并拉取最新代码,避免“在旧代码上开发”

git switch dev
git pull origin dev

第 3 步:暂存并提交

git add .
git commit -m "feat: 完成登录页按钮交互优化"

第 4 步:推送到远程团队分支

git push origin dev

单分支场景的关键提醒

五、场景二:多分支协作(主流团队工作流)

这个场景更常见于规范化团队:main/master 保持稳定,每个需求在独立分支完成,再合并回主干。

目标

从主干拿最新代码,创建自己的功能分支,完成开发后合并回目标分支。

推荐流程

第 1 步:先更新主干代码

git switch main
git pull origin main

第 2 步:创建并切换到功能分支

git switch -c feature/login-form

分支名建议包含业务语义,如 feature/fix/ 前缀。

第 3 步:暂存并提交

git add .
git commit -m "feat: 新增登录表单校验逻辑"

一个完整功能可以拆成多个小提交,方便 review 和回滚。

第 4 步:推送分支并建立远程跟踪

git push -u origin feature/login-form

-u 只需第一次使用,后续直接 git push 即可。

第 5 步:合并代码(两种常见方式)

方式 A(推荐):在代码平台发起 PR / MR,由评审后合并。
方式 B(本地演示):切回目标分支后手动合并:

git switch main
git pull origin main
git merge feature/login-form
git push origin main

第 6 步:合并完成后清理分支

git branch -d feature/login-form
git push origin --delete feature/login-form

本地和远程都清理掉已合并分支,分支列表会更清爽。

六、两个场景都通用的常见问题

1)pull或merge冲突了

说明同一代码区域被不同提交修改。处理方法:手动解决冲突文件后,再 addcommit

2)常见撤销操作(建议记住这 3 条)

# 取消暂存
git restore --staged <文件>

# 丢弃工作区改动(单个文件)
git restore <文件>

# 丢弃当前目录改动
git restore .

3)当前改动没做完,但要临时切走处理其他事情

git stash
git switch 其他分支
# 处理完回来
git switch 原分支
git stash pop

七、总结:先练熟“场景流程”,再背命令

最重要的不是记住多少个命令,而是跑通完整流程。

当这两套流程熟练后,你再学习 rebase、cherry-pick等会轻松很多。

到此这篇关于Git单分支与多分支的协作流程的文章就介绍到这了,更多相关Git单分支与多分支协作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文