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位,操作时写前五位即可,因为查看的时候一般也只有前五位)。

相关推荐
Amazing_Cacao3 小时前
深度观察 | 从“产区玄学”到“液态战场”:精品巧克力的终极试金石
学习
ZTL-NPU4 小时前
Jetbrains开发ros
ide·python·pycharm·编辑器·ros·clion
张同学034 小时前
220V 转 12V/5V 电源输入电路设计笔记
笔记·嵌入式硬件·硬件工程
深蓝海拓4 小时前
S7-1500PLC学习笔记:MOVE_BLK、MOVE_BLK_VARIANT、BLKMOV的区别
笔记·学习·plc
杨浦老苏5 小时前
开源的AI编程工作站HolyClaude
人工智能·docker·ai·编辑器·开发·群晖
darkhorsefly5 小时前
玩24算的益处
学习·游戏·24算
雨浓YN6 小时前
OPC UA 通讯开发笔记 - 基于本地dll文件
windows·笔记
深蓝海拓6 小时前
S7-1500学习笔记:用户自定义数据类型(UDT)
笔记·学习·plc
罗罗攀7 小时前
PyTorch学习笔记|神经网络的损失函数
人工智能·pytorch·笔记·神经网络·学习
aP8PfmxS27 小时前
从零学习Kafka:数据存储
分布式·学习·kafka