Git学习笔记:Git进阶操作

这一篇文章我们来介绍Git对暂存区的操作。

暂存区,顾名思义,就是把东西暂存到里面,这样可以方便修改和撤销。实际上,"暂存区"才是 Git 最精华、最核心的设计,也是Git区别于其他老式版本控制工具的根本所在。

为什么要使用暂存区?

设想你正在开发一个复杂的系统,你在做一个版本的修改,但是这个修改改动的地方较多,你不会每改一个地方就git commit一次到仓库,所以,这个时候暂存区的作用就显示出来了,直到你真正的确定了你的文件内容修改完毕了,你才将暂存区的东西提交到仓库,这样就可以保证你每次提交的东西都是经过多次打磨,深思熟虑的版本。

简单来说,暂存区就是你打磨下一个版本的地方。

暂存区的操作命令

  • git ls-files

    当你觉得git status显示混乱时,用这个命令确认"到底哪些文件已经被add了"。

    这样方便本次的一个修改。

  • 撤销操作:把文件"拿出"暂存区

    如果我add错了怎么办?

    这个命令分为两个:

  • git restore 文件名:撤销工作区修改(从暂存区恢复)

  • git restore --staged 文件名: 撤销暂存区修改(保留工作区的修改)
    注意:这两个命令有本质的区别,前者是从暂存区恢复到工作区(那刚刚工作区写的代码就没有了),后者是撤销暂存区的文件(工作区的文件还在,暂存区的提交就被撤销了)。

  1. 基于暂存区的回退
    在开发的过程中,我们难免会把代码写的比较乱,如果你不想要某一次写的代码了,可以回退版本。
    有三个命令,他们的作用各有不同:
bash 复制代码
git reset --soft 版本号
git reset --mixed 版本号
git reset --hard 版本号

作用如下:

bash 复制代码
git reset --soft 版本号 回退到指定版本(保留工作区和暂存区)
git reset --mixed 版本号 回退到指定版本(保留工作区,撤销暂存区)
git reset --hard 版本号 回退到指定版本(撤销工作区和暂存区)

这三个命令各有各的作用,如果不带--mixed这种命令的话,默认是--mixed

这里需要注意的是,--hard会导致彻底回退,需要谨慎使用。

补充

这里补充一个知识点:

如果不小心将代码误删了,可以使用git reflog命令查看历史的记录,然后再使用git reset --hard 版本号来进行恢复即可(Git里面的版本哈希值是40位,操作时写前五位即可,因为查看的时候一般也只有前五位)。

相关推荐
OSwich4 分钟前
【 Godot 4 学习笔记】数组(Array)
笔记·学习·godot
程序员-小李11 分钟前
uv 学习总结:从零到一掌握现代化 Python 工具链
python·学习·uv
数据皮皮侠AI17 分钟前
中国城市可再生能源数据集(2005-2021)|顶刊 Sci Data 11 种能源面板
大数据·人工智能·笔记·能源·1024程序员节
其实防守也摸鱼1 小时前
面试常问问题总结--护网蓝队方向
网络·笔记·安全·面试·职场和发展·护网·初级蓝队
nashane1 小时前
HarmonyOS 6学习:页面跳转弹窗状态保持全解析
学习·华为·harmonyos·harmonyos 5
山楂树の1 小时前
图像标注大坑:img图片 + Canvas 叠加标注,同步放大后标注位置偏移、对不齐?详解修复方案及亚像素处理原理
前端·css·学习·canva可画
小郑加油1 小时前
python学习Day10天:列表进阶 + 内置函数 + 代码简化
开发语言·python·学习
z19408920662 小时前
Word题库转结构化:告别换行、选项与答案乱象
经验分享·笔记·语音识别
Bechamz3 小时前
大数据开发学习Day23
大数据·学习·ajax
坚持就完事了3 小时前
YARN资源管理器
大数据·linux·hadoop·学习