git工作区与暂存区的文件修改、还原

查看暂存区文件

git ls-files 命令是用来查看暂存区中文件信息.
参数说明:

  • –cached(-c)显示暂存区中的文件,git ls-files命令默认的参数
  • –deleted(-d)显示删除的文件
  • –modified(-m) 显示修改过的文件
  • –other(-o)显示没有被git跟踪的文件
  • –stage(-s) 显示mode以及文件对应的Blob对象,进而我们可以获取暂存区中对应文件里面的内容。

实例:
1.查看暂存区中有哪些文件?
git ls-files
在这里插入图片描述
2.查看暂存区中test.txt文件内容是什么?
首先,我们需要查查test.txt文件对应的Blob对象,如下:
git ls-files -s – test.txt 或者直接 git ls-files -s
在这里插入图片描述
然后通过Blob对象,查询test.txt里面的内容:
git cat-file -p 43ac
在这里插入图片描述

还原暂存区的文件

  • 当自己在工作区修改或删除某一指定文件,但该文件有一个版本已经上传至暂存区时,可以通过git restore [fileName]将暂存区文件的复制加入到当前工作区。如果该文件被删除,则该文件会被复原;如果该文件被修改,那么文件就会回到修改前的状态。

删除情况

  • 新建一个new.txt。
  • 通过git add new.txt上传至暂存区。
  • 通过rm new.txt删除该文件。
  • 通过git ls-files查看到该文件在暂存区有保留。
  • 通过git restore new.txt使暂存区保留的new.txt复制一份到工作区

修改情况

  • 新建一个new.txt,写入“版本一”字符串。
  • 上传至暂存区。
  • 修改new.txt的内容为“版本二”
  • 执行git restore new.txt,查看工作区的new.txt文件的内容是“版本一”

删除暂存区的文件

  • git rm -r --cached [fileName]
  • git reset HEAD [fileName]:指定文件回退到最近一次执行push后的的状态,清空暂存区,同时回退工作区文件状态。
  • 此时若文件曾被提交至本地库,由于快照与工作区文件不匹配进而提示’deleted : new.txt’,将工作区文件重新提交至本地库即可。如果文件仅仅提交至暂存区而没有提交至本地库,文件在被删除或修改后不会有提示。
  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `git reset --hard` 命令会将 Git 仓库中的 HEAD 指向指定的提交,同时重置暂存区工作,这样会丢失工作中未提交的修改和所有已暂存但未提交的修改。 如果你只是想撤销暂存区修改,可以使用以下命令: ``` git reset HEAD ``` 这个命令会将暂存区修改撤销,但不会影响工作修改。如果你想撤销工作修改,可以使用以下命令: ``` git checkout . ``` 这个命令会将工作中所有修改还原到最近的一次提交状态。注意,所有未提交的修改都会被丢弃,因此请谨慎使用。 ### 回答2: git reset --hard 暂存文件是指使用git的reset命令来重置工作暂存区,并且放弃对某个文件的更改,恢复到之前的提交状态。 当我们在进行代码开发时,有时可能会修改一些文件,但事后发现自己的修改是错误的或不需要的。此时,我们可以使用git reset --hard命令来撤销对这些文件修改。 使用git reset --hard命令,会同时重置工作暂存区,将它们恢复到上一次提交的状态。这个命令会永久性地丢弃我们对文件修改,所以在执行这个命令之前,一定要确保我们不需要保存这些修改。 要使用git reset --hard命令,我们需要先确定要重置的提交版本或分支。可以通过git log命令来查看提交记录,找到我们需要回滚到的版本号或提交哈希。然后,在终端中输入git reset --hard <提交哈希>命令,将工作暂存区重置到指定的提交。 需要注意的是,git reset --hard命令会永久性地丢弃所有没有提交的修改,所以在执行这个命令之前,一定要确认工作中没有重要的未保存的更改。在重置之前,也可以使用git stash命令将修改文件暂存起来,以便稍后可以恢复到当前状态。 综上所述,git reset --hard 暂存文件是一个强制性的重置命令,它可以丢弃对文件修改,恢复到之前的提交状态。但是由于这个命令会永久地丢弃未提交的更改,使用之前需要谨慎确认。 ### 回答3: git reset --hard 对于暂存文件的作用是把所有已暂存的文件回退到最近一次提交的状态。也就是说,执行这个命令后,暂存区中的文件会被清空,工作目录中的文件会与最近一次提交的版本完全一致。 当我们使用 git add 命令将文件添加到暂存区后,我们有时可能会发现自己添加了一些不必要的或错误的文件。这时,可以使用 git reset --hard 暂存文件来撤销这些暂存的文件,使其回到工作目录并且不出现在暂存区中。 另外,当我们想要回退到之前某个提交的状态时,可以使用 git reset --hard 加上想要回退的提交的SHA值来实现。执行该命令后,Git会将HEAD指针和分支指针移动到指定的提交上,并且重置工作目录和暂存区到该提交的状态。这意味着,我们回退后之前的提交及其之后的提交都会被丢弃,工作目录和暂存区会和指定的提交完全一致。 需要注意的是,git reset --hard 命令是具有破坏性的,它会永久性地清空暂存区工作目录中的文件,并且丢弃掉之前的提交。因此,在执行该命令之前,需要确保已经备份了重要的更改,以免造成数据的不可挽回的损失。 总之,git reset --hard 暂存文件命令用于撤销暂存的文件,或者回退到之前某个提交的状态,但需要谨慎使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值