📚 Git 必知必会
🧭 文章目录(点击跳转)
Git 全面指南
分支策略大全
合并与变基
冲突解决实战
高级操作技巧
性能与团队协作
功能分支
Gitflow
Forking
主干开发
合并 vs 变基
快进与非快进
冲突解决步骤
实战示例
Stash
Cherry-pick
Tag
Submodule
大文件处理
团队协作流程
代码审查
📌 快速导航
- [一、Git 分支策略:哪种适合你的团队?](#一、Git 分支策略:哪种适合你的团队?)
- [二、合并 vs 变基:你到底该选哪个?](#二、合并 vs 变基:你到底该选哪个?)
- 三、冲突解决:别再慌,一步步来
- 四、高级操作:Stash、Cherry-pick、Tag、Submodule
- 五、性能优化与团队协作
- [六、Git 面试高频题精选](#六、Git 面试高频题精选)
- 七、互动与转载声明
一、Git 分支策略:哪种适合你的团队?
🎯 核心知识
Git 分支策略就像"团队作战计划",选对了事半功倍,选错了天天救火。
📖 专业解释
常见的 Git 分支策略有四种:
-
功能分支工作流
每个功能一个分支,互不干扰。适合多人并行开发。
-
Gitflow 工作流
有
develop、feature、release、hotfix等分支,适合版本迭代频繁的中大型项目。 -
Forking 工作流
每人一个远程仓库,适合开源项目或严格代码审查环境。
-
主干开发
所有人都在
main分支上开发,适合持续集成、快速迭代的团队。
🍔 生活案例
好比开餐厅:
- 功能分支 = 每个厨师做一个菜,不互相抢锅。
- Gitflow = 有备菜区、炒菜区、出餐区、应急修补区。
- Forking = 每个厨师自带厨房,做完再合并到总店。
- 主干开发 = 所有人共用一个大厨房,实时协作。
二、合并 vs 变基:你到底该选哪个?
🎯 核心知识
merge 是"合照",rebase 是"P图"。
📖 专业解释
- Merge:保留所有分支历史,生成一个合并提交。
- Rebase:把当前分支的提交"接"到目标分支后面,历史更整洁。
⚠️ 注意事项
rebase会改写历史,不要在公共分支上用!merge会保留完整上下文,适合团队协作。
🍔 生活案例
- Merge = 你和朋友合照,两人都在照片里。
- Rebase = 你把自己P到朋友的照片里,看起来像一直在一起。
三、冲突解决:别再慌,一步步来
🎯 核心知识
冲突不可怕,可怕的是不会解决。
📖 专业解释
解决冲突四步法:
- 识别冲突 :
git status看哪些文件冲突。 - 手动编辑 :打开文件,找到
<<<<<<<、=======、>>>>>>>标记的区域。 - 标记解决 :
git add <文件>告诉 Git 你搞定了。 - 完成合并 :
git commit提交合并结果。
🧪 实战示例
bash
git merge feature-branch
# 发现冲突,手动修改文件
git add conflicted-file.txt
git commit -m "解决合并冲突,融合 feature-branch 的改动"
四、高级操作:Stash、Cherry-pick、Tag、Submodule
🔸 Git Stash:临时存个档
当你写着代码突然要切分支,又不想提交半成品:
bash
git stash # 存档
git stash list # 查看存档列表
git stash pop # 取档
🔸 Cherry-pick:只拿想要的提交
就像只从一个篮子里挑几个苹果:
bash
git cherry-pick <提交哈希>
🔸 Tag:给版本拍个照
适合标记发布版本:
bash
git tag v1.0.0
git push --tags
🔸 Submodule:仓库里的仓库
适合管理依赖库:
bash
git submodule add https://github.com/xxx/lib.git
git submodule update --init --recursive
五、性能优化与团队协作
🚀 大文件处理
用 Git LFS 存储大文件,别让仓库变"肥宅":
bash
git lfs install
git lfs track "*.psd"
git add .gitattributes
👥 代码审查流程
- 创建 Pull Request
- 团队成员评论、建议
- 修改后再提交
- 合并到主分支
🧹 定期清理
bash
git gc --prune=now --aggressive
六、Git 面试高频题精选
| 问题 | 核心回答 |
|---|---|
git fetch 和 git pull 区别? |
fetch 只下载,pull = fetch + merge |
| 如何撤销已推送的提交? | 用 git revert(安全),慎用 git reset --hard + push --force |
| 什么是快进合并? | 分支可直接向前移动,不创建新提交 |
| 如何找回删除的分支? | git reflog 找哈希,git checkout -b 新分支 哈希 |
七、互动与转载声明
💬 互动环节
你是 Git 高手还是小白?平时最爱用哪个命令?
欢迎在评论区分享你的 Git 神操作或踩坑经历!点赞最高的评论送"Git 学习秘籍"一份~
📜 转载声明
转载声明:本文原创,转载请注明出处。