文章目录
- [1. Git核心概念回顾🎯](#1. Git核心概念回顾🎯)
-
- [1.1 什么是Git?](#1.1 什么是Git?)
- [1.2 Git的特点](#1.2 Git的特点)
- [1.3 Git与SVN对比](#1.3 Git与SVN对比)
- [2. Git工作流程详解🔄](#2. Git工作流程详解🔄)
-
- [2.1 四个工作区域](#2.1 四个工作区域)
- [2.2 文件状态转换](#2.2 文件状态转换)
- [3. 常用命令总结⚙️](#3. 常用命令总结⚙️)
-
- [3.1 基础操作命令](#3.1 基础操作命令)
- [3.2 分支管理命令](#3.2 分支管理命令)
- [3.3 远程仓库操作](#3.3 远程仓库操作)
- [4. 实践案例:多人协作开发🛠️](#4. 实践案例:多人协作开发🛠️)
-
- [4.1 场景描述](#4.1 场景描述)
- [4.2 操作流程](#4.2 操作流程)
- [4.3 冲突解决](#4.3 冲突解决)
- [5. 常见问题与解决方案❓](#5. 常见问题与解决方案❓)
-
- [5.1 忘记添加文件到暂存区](#5.1 忘记添加文件到暂存区)
- [5.2 提交信息写错](#5.2 提交信息写错)
- [5.3 误删文件](#5.3 误删文件)
- [5.4 远程仓库连接问题](#5.4 远程仓库连接问题)
- [6. 学习心得与建议💡](#6. 学习心得与建议💡)
-
- [6.1 Git学习路径](#6.1 Git学习路径)
- [6.2 最佳实践](#6.2 最佳实践)
- [7. Git知识体系思维导图🧠](#7. Git知识体系思维导图🧠)
- [8. 总结📈](#8. 总结📈)
📝 引言
之前我写过关于Git的文章
那么这篇文章,只要对于需要快速复习的读者
如果你想快速回顾和复习Git的知识点
我想这篇文章,一定能够帮助到你!
后面的思维导图对你一定有帮助
个人主页:艺杯羹
系列专栏:Git系列
1. Git核心概念回顾🎯
1.1 什么是Git?
Git是一种分布式版本控制系统 ,由Linus Torvalds在2005年创建
与传统的集中式版本控制系统(如SVN)不同,Git的每个工作目录都是一个完整的仓库,包含项目的完整历史记录
1.2 Git的特点
- 分布式:每个开发者都有完整的代码仓库副本
- 高效:本地操作速度快,网络传输少
- 分支管理:强大的分支和合并功能
- 数据完整性:使用SHA-1算法确保数据完整性
1.3 Git与SVN对比
| 特性 | Git | SVN |
|---|---|---|
| 存储方式 | 分布式 | 集中式 |
| 离线工作 | 支持 | 不支持 |
| 分支管理 | 强大 | 较弱 |
| 数据存储 | 快照式 | 差异式 |
2. Git工作流程详解🔄
2.1 四个工作区域
Workspace 工作区
Index 暂存区
Repository 仓库区
Remote 远程仓库
2.2 文件状态转换
| 状态 | 描述 | 转换方式 |
|---|---|---|
| Untracked | 未跟踪,未加入Git库 | git add → Staged |
| Unmodified | 已入库,未修改 | 修改 → Modified git rm → Untracked |
| Modified | 已修改,未暂存 | git add → Staged git checkout → Unmodified |
| Staged | 已暂存,待提交 | git commit → Unmodified git reset → Modified |
3. 常用命令总结⚙️
3.1 基础操作命令
bash
# 初始化仓库
git init
# 添加文件到暂存区
git add <文件名>
git add . # 添加所有文件
# 提交更改
git commit -m "提交信息"
# 查看状态
git status
# 查看日志
git log
git log --oneline # 简洁显示
git log --graph # 显示分支合并图
# 比较差异
git diff # 工作区 vs 暂存区
git diff --cached # 暂存区 vs 仓库区
3.2 分支管理命令
bash
# 创建分支
git branch <分支名>
# 切换分支
git checkout <分支名>
# 创建并切换分支
git checkout -b <分支名>
# 合并分支
git merge <分支名>
# 删除分支
git branch -d <分支名>
3.3 远程仓库操作
bash
# 添加远程仓库
git remote add origin <仓库地址>
# 推送本地分支到远程
git push origin <分支名>
# 拉取远程更新
git pull origin <分支名>
# 克隆仓库
git clone <仓库地址>
4. 实践案例:多人协作开发🛠️
4.1 场景描述
假设团队中有两个开发者A和B,共同开发一个项目,可能会遇到冲突问题。
4.2 操作流程
bash
# 开发者A
git clone https://gitee.com/yibeigen.git
# 创建一个分支,并且切换到这个分支
git checkout -b feature/login
# 修改登录功能
git add .
git commit -m "实现登录功能"
git push origin feature/login
# 开发者B
git clone https://gitee.com/yibeigen.git
git checkout -b feature/register
# 修改注册功能
git add .
git commit -m "实现注册功能"
git push origin feature/register
# 合并分支
git checkout master
git merge feature/login
git merge feature/register
4.3 冲突解决
当两个开发者修改同一文件时,会出现冲突:
<<<<<<< HEAD
# 你自己写的代码
this is xiaoyi
=======
# 别人写的代码
public class HelloWorld{}
>>>>>>> 0b8b926afc79bd22d220bd0cb76ef7d97b5fb5d4
解决方法:
- 手动编辑文件,保留需要的代码
- 标记冲突已解决:
git add <文件名> - 提交更改:
git commit -m "解决冲突"
5. 常见问题与解决方案❓
5.1 忘记添加文件到暂存区
bash
git add .
git commit -m "补充遗漏文件"
5.2 提交信息写错
bash
git commit --amend -m "正确的提交信息"
5.3 误删文件
bash
git checkout -- <文件名> # 恢复工作区文件
5.4 远程仓库连接问题
bash
# 生成SSH密钥
ssh-keygen -t rsa
# 添加公钥到GitHub/Gitee
cat ~/.ssh/id_rsa.pub
6. 学习心得与建议💡
6.1 Git学习路径
- 基础命令 :掌握
add、commit、status等基本操作 - 分支管理 :理解分支概念,熟练使用
branch、checkout、merge - 远程协作 :学习
push、pull、clone等远程操作 - 高级技巧 :掌握
rebase、cherry-pick等高级功能
6.2 最佳实践
- 频繁提交:每次完成一个小功能就提交
- 清晰的提交信息:使用有意义的提交信息
- 分支策略:使用Git Flow等分支管理策略
- 定期同步:及时与远程仓库同步
7. Git知识体系思维导图🧠

8. 总结📈
通过本次Git复盘,我们系统地回顾了Git的核心概念、工作流程和常用操作。Git作为版本控制工具,不仅能够帮助我们管理代码版本,还能促进团队协作。掌握Git的技能对于每个开发者来说都是至关重要的
学习建议:
- 多实践,多使用
- 理解Git的底层原理
- 学习团队协作的最佳实践
- 关注Git的新特性和工具
希望本文能够帮助您更好地理解和应用Git,在版本控制的道路上越走越远!(* ̄︶ ̄)