jjzjj

git reset HEAD 用法

~kiss~ 2024-06-25 原文


【git技巧】
参考博客:https://blog.csdn.net/crjmail/article/details/100011063

git add 时,误添加不想提交的文件,如何解决?

  1. 误add所有文件
    git reset HEAD
    将所有此次修改的 file 退回到工作区

  2. 误add单个文件,只撤销部分文件
    git reset HEAD file
    将此次修改的这个 file 退回到工作区

以上操作使得被操作的文件图标从绿色变红色。

【注意】
git add 是将文件从工作区–>暂存区
git commit 是将文件从暂存区–>git本地仓库

如果 git add 一个 file 之后,又操作了该文件但未 git add ,且两次操作的地方有冲突
再 git reset HEAD file 时,文本内容将是后面的操作,而不是前面的回退

eg:
(1) 先修改 1.c 的 main 为 mai1n
$ git diff
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
-main
+mai1n

(2) 放到暂存区
$ git add .

(3) 再次修改 1.c 的 main 为 mai2n
$ git diff
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
-mai1n
+mai2n

(4) 查看 git 状态
$ git status
Changes to be committed:
modified: 1.c
Changes not staged for commit:
modified: 1.c

(5) 回退暂存区
$ git reset HEAD 1.c
Unstaged changes after reset:
M 1.c

(6) 查看状态
$ git status
Changes not staged for commit:
modified: 1.c

$ git diff
diff --git a/1.c b/1.c
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
-main
+mai2n

如果 git add 一个 file 之后,又操作了该文件但未 git add ,且两次操作的地方不冲突
再 git reset HEAD file 时,文本内容将是后面的操作,而不是前面的回退

(1) 修改 1.c
$ git diff
diff --git a/1.c b/1.c
index 0bd96f3…f9e2dc8 100644
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
hello world
-main
+main123
study

(2) 放到暂存区
$ git add .

(3) 再次修改 1.c ,在最后一行添加一行 “love”, 但是不 git add
$ git status
On branch master
Changes to be committed:
modified: 1.c
Changes not staged for commit:
modified: 1.c

$ git diff
diff --git a/1.c b/1.c
index f9e2dc8…a521094 100644
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
hello world
main123
study
+love

(4) 回退暂存区
$ git reset HEAD 1.c
Unstaged changes after reset:
M 1.c

$ git diff
diff --git a/1.c b/1.c
index 0bd96f3…a521094 100644
— a/1.c
+++ b/1.c
@@ -1,4 +1,4 @@
hello world
-main
+main123
study

+love

这应该是 git reset HEAD file 的一份风险点

【it rm 与 git reset的区别】
git rm:用于从工作区和索引中删除文件
git reset:用于将当前HEAD复位到指定状态。一般用于撤消之前的一些操作(如:git add,git commit等)。

git rm -f file_path
删除暂存区和分支上的文件,同时工作区也不需要

git rm --cached file_path
删除暂存区或分支上的文件, 但工作区需要使用, 只是不希望被版本控制

git reset HEAD 回退暂存区里的文件

有关git reset HEAD 用法的更多相关文章

  1. ruby - 有人可以解释一下在 Ruby 中注入(inject)的真实、通俗易懂的用法吗? - 2

    我正在学习Ruby,遇到了inject。我正处于理解它的风口浪尖,但当我是那种需要真实世界的例子来学习一些东西的人时。我遇到的最常见的例子是人们使用inject来添加一个(1..10)范围的总和,我不太关心这个。这是一个任意的例子。在实际程序中我会用它做什么?我正在学习,所以我可以继续使用Rails,但我不必有一个以Web为中心的示例。我只需要一些我可以全神贯注的目标。谢谢大家。 最佳答案 inject有时可以通过它的“其他”名称reduce更好地理解。它是一个对Enumerable进行操作(迭代一次)并返回单个值的函数。它有许多有

  2. ruby - 使用法拉第上传文件 - 2

    我在尝试使用Faraday将文件上传到网络服务时遇到问题。我的代码:conn=Faraday.new('http://myapi')do|f|f.request:multipartendpayload={:file=>Faraday::UploadIO.new('...','image/jpeg')}conn.post('/',payload)尝试发布后似乎没有任何反应。当我检查响应时this是我所看到的:#:post,:body=>#,#,@opts={}>,#],@index=0>>,#>],@ios=[#,#,@opts={}>,#],@index=0>,#],@index=0>

  3. ruby - rspec: raise_error 用法来匹配错误信息 - 2

    我使用raise(ConfigurationError.new(msg))引发错误我试着用rspec测试一下:expect{Base.configuration.username}.toraise_error(ConfigurationError,message)但这行不通。我该如何测试呢?目标是匹配message。 最佳答案 您可以使用正则表达式匹配错误消息:it{expect{Foo.bar}.toraise_error(NoMethodError,/private/)}这将检查NoMethodError是否由privateme

  4. 【ChatGPT】ChatGPT 的 N 种用法 - 2

    目录ChatGPT简介技术原理应用未来发展ChatGPT的10 种用法ChatGPT简介ChatGPT是一种基于深度学习的大型语言模型,由OpenAI公司开发。技术原理GPT是GenerativePre-trainedTransformer的缩写,意为生成式预训练变压器。它的技术原理是使用了一个基于注意力机制的变压器(Trans

  5. ruby - 是否有 Rack::Session::Cookie 用法的基本示例? - 2

    我找不到任何使用Rack::Session::Cookie的简单示例,并且希望能够将信息存储在cookie中,并在以后的请求中访问它并让它过期.这些是我能找到的唯一示例:HowdoIset/getsessionvarsinaRackapp?http://rack.rubyforge.org/doc/classes/Rack/Session/Cookie.html这是我得到的:useRack::Session::Cookie,:key=>'rack.session',:domain=>'foo.com',:path=>'/',:expire_after=>2592000,:secret=

  6. ruby - Ruby 方法的双冒号(双列或::)语法的惯用用法 - 2

    我是Ruby的新手,发现以下几对令人困惑示例同样有效:File.included_modulesFile::included_modulesFile.stat('mbox')#Returnsa'#'objectFile::stat('mbox')File.new("foo.txt","w")File::new("foo.txt","w")"asdf".size#Aninstancemethod"asdf"::size2+32::send(:+,3)#AnextremeexampleFile::new,尤其是我经常遇到的东西。我的问题:如果我永远避免使用::运算符来限定除类、模块和常量之

  7. ruby-on-rails - 如果只有一个存在,是否有用于返回第一个数组元素的 ruby​​ 习惯用法? - 2

    如果数组只包含一个值,我想返回数组的第一个元素。目前,我使用:vals.one??vals.first:vals.presence因此:vals=[];vals.one??vals.first:vals.presence#=>nilvals=[2];vals.one??vals.first:vals.presence#=>2vals=[2,'Z'];vals.one??vals.first:vals.presence#=>[2,"Z"]是否有内置的东西可以做到这一点,或者是否有更好的设计考虑?我的用例是特定的,涉及知道从方法(将实现上述代码)中期望什么的演示者。如果这些演示者将所有返回

  8. ruby - 这是 &&= 在 Ruby 中的合理用法吗? - 2

    在SOquestion2068165一个答案提出了使用这样的东西的想法:params[:task][:completed_at]&&=Time.parse(params[:task][:completed_at])作为DRYer的说法params[:task][:completed_at]=Time.parse(params[:task][:completed_at])ifparams[:task][:completed_at]paramsHash将来自(Rails/ActionView)表单。这是众所周知的||=习语的一种推论,如果LHS不是nil/false则设置值。像这样使用&&

  9. ruby - Head 用法未知选项 -1/-n 错误。可能与 ruby 有关 - 2

    我在OSX10.9.1中启动终端时反复出现问题。每次启动终端时,我都会重复以下至少30次Unknownoption:1Usage:head[-options]...-musemethodfortherequest(defaultis'HEAD')-fmakerequestevenifheadbelievesmethodisillegal-bUsethespecifiedURLasbase-tSettimeoutvalue-iSettheIf-Modified-Sinceheaderontherequest-cusethiscontent-typeforPOST,PUT,CHECKIN-

  10. ruby-on-rails - rails 中是否内置了对默认值替换习惯用法的支持? - 2

    我经常编写代码以在遇到nil/空值时提供默认值。例如:category=order.category||"Any"#ORcategory=order.category.empty??"Any":order.category我即将扩展try方法来处理这个习语。category=order.try(:category,:on_nill=>"Any")#ORcategory=order.try(:category,:on_empty=>"Any")我想知道Rails/Ruby是否有一些方法来处理这个习惯用法?注意:我正在尝试消除||的重复/或/?基于运算符的习语。本质上,我正在寻找与try方

随机推荐