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

相关推荐
nqqcat~2 小时前
hlist哈希链表学习笔记
学习·链表·哈希算法
CDN3602 小时前
运维笔记|360CDN高防服务器部署教程,抗D+源站防护一站式配置
运维·服务器·笔记
林鸿群2 小时前
Cocos2d-x 官方仓库学习总结
学习·游戏引擎·cocos2d
左左右右左右摇晃2 小时前
Java Object 类笔记
java·笔记
橘bird2 小时前
LangChain1.2 学习笔记(自用)(未完结)
笔记·python·学习·langchain
智者知已应修善业2 小时前
【任何一个自然数m的立方均可写成m个连续奇数之和】2024-10-17
c语言·数据结构·c++·经验分享·笔记·算法
小霍同学2 小时前
Git Commit 规范与相关工具
git
fengyehongWorld2 小时前
SourceTree 推送后修改commit message
git·sourcetree