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

相关推荐
二哈赛车手20 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
吃好睡好便好20 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
nashane21 小时前
HarmonyOS 6学习:CapsLock键失效诊断与长截图完整实现指南
学习·华为·harmonyos
cen__y1 天前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
xian_wwq1 天前
【学习笔记】AGC协调控制系统概述
笔记·学习
x_yeyue1 天前
三角形数
笔记·算法·数论·组合数学
憧憬成为java架构高手的小白1 天前
docker学习笔记(基于b站多个视频学习)【未完结】
笔记·学习
辰海Coding1 天前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
时空自由民.1 天前
vim入门配置教程
编辑器·vim·excel
RainCity1 天前
Java Swing 自定义组件库分享(七)
java·笔记·后端