git 命令怎么退回到当前版本未修改之前的状态?

简介: git 命令怎么退回到当前版本未修改之前的状态?

在此之前,我们先了解一下工作区和暂存区:



工作区(Working Directory)


就是你在电脑里能看到的目录,比如下面的 learngit 文件夹就是一个工作区:

c54f3c7e98974662855fa614c3f3ab9c.png




暂存区

工作区有一个隐藏目录 .git,这个不算工作区,而是Git的版本库(Repository)。


Git 的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有 Git 为我们自动创建的第一个分支 master,以及指向 master 的一个指针叫 HEAD。


f66e99d74c7f4e74bbf7b25ea4050e91.png


git add 把文件添加进去,实际上就是把文件修改添加到暂存区;



6155fa9f0666468bb076fb4a0f0004aa.png


git commit 提交更改,实际上就是把暂存区的所有内容提交到当前分支。


7afaf57747924a7ea68f10c8ec310592.png


总的来说就是需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

下面开始正题,要退回到当前版本需要分情况



1、没有 add(没有添加到暂存区)


这里只有一步就是:丢弃工作区的修改

撤销一个文件修改:

git checkout -- 文件名


撤销全部文件修改:

git checkout -- .



2、已经 add,但是没有 commit(已经添加到暂存区)

第一步:撤销暂存区的文件(撤销add)


把暂存区的修改撤销掉(unstage),重新放回工作区:

git reset HEAD <file>



撤销这次所有暂存区的文件

git reset HEAD .


第二步:丢弃工作区的修改

这个就是跟 没有 add(没有添加到暂存区) 的处理一样:

撤销一个文件修改:

git checkout -- 文件名


撤销全部文件修改:

git checkout -- .


目录
相关文章
|
15天前
|
缓存 Java Shell
[Git]入门及其常用命令
本文介绍了 Git 的基本概念和常用命令,包括配置、分支管理、日志查看、版本回退等。特别讲解了如何部分拉取代码、暂存代码、删除日志等特殊需求的操作。通过实例和图解,帮助读者更好地理解和使用 Git。文章强调了 Git 的细节和注意事项,适合初学者和有一定基础的开发者参考。
36 1
[Git]入门及其常用命令
|
1月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
112 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
19天前
|
开发工具 git 开发者
|
19天前
|
开发工具 git 开发者
提升Git效率:掌握这5个高级命令
【10月更文挑战第17天】
40 0
|
2月前
|
安全 开发工具 git
git合并错了,我想回退到之前的版本
git合并错了,我想回退到之前的版本
|
2月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
无论团队项目还是个人开发,掌握 Git 命令都是必备技能。本文介绍 Git 的基本概念与命令,如初始化仓库 (`git init`)、添加文件 (`git add`)、提交更改 (`git commit`)、检出分支 (`git checkout`)、合并分支 (`git merge`) 等,还分享了高级技巧如查看差异 (`git diff`)、撤销提交 (`git revert`)、修复合并冲突 (`git mergetool`) 和使用别名简化命令 (`git config --global alias.ci commit`)。
|
2月前
|
机器学习/深度学习 Shell 开发工具
Python使用管道执行git命令报错|4-7
Python使用管道执行git命令报错|4-7
|
2月前
|
存储 Linux 开发工具
Git基础命令,分支,标签的使用【快速入门Git】
本文详细介绍了Git版本控制系统的基础概念和常用命令,包括工作区、暂存区和版本库的区别,文件状态的变化,以及如何进行文件的添加、提交、查看状态、重命名、删除、查看提交历史、远程仓库操作和分支管理,还涉及了Git标签的创建和删除,旨在帮助读者快速入门Git。
Git基础命令,分支,标签的使用【快速入门Git】
|
2月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
本文介绍 Git 的核心概念,如仓库、提交、分支与合并,并提供了常用命令,如初始化仓库 (`git init`)、提交更改 (`git commit -m &quot;Commit message&quot;`)、拉取 (`git pull`) 和推送 (`git push`) 等。此外,还分享了高级技巧,如撤销提交 (`git revert &lt;commit&gt;`)、交互式暂存 (`git add -i`) 和使用别名简化命令 (`git config --global alias.ci commit`) 等,帮助开发者提升效率。无论是初学者还是资深开发者,都能从中受益。
|
2月前
|
开发工具 git 开发者
GIT命令的综合总结
Git的学习曲线可能比较陡峭,但熟练掌握这些命令后,你将能够更加高效地管理和协作你的项目。希望这份指南能帮助你成为Git的高效用户。
49 7