为什么 git 允许我重置文件?我以为我明白了reset
,从某种意义上说,它正在移动头部……显然我错了。
So, git reset sha file
似乎做同样的事情git checkout sha file
,除了我看到的file
在索引和工作目录中。
这对我来说没有意义。有人可以解释一下区别吗?
tl;dr git reset COMMIT FILE
仅更改索引,git checkout COMMIT FILE
将更改索引和工作树。
git reset
有非常重要的标志--soft
, --hard
and --mixed
( and --keep
and --merge
)
http://git-scm.com/docs/git-reset http://git-scm.com/docs/git-reset
--mixed
是默认值,当你这样做时git reset sha file
你正在做mixed
重置由此:
--mixed
重置索引但不重置工作树(即更改的文件
被保留但未标记为提交)并报告尚未提交的内容
更新。这是默认操作。
就像上面所说的那样,这种情况下的重置根本不会影响你的工作树,只有索引中的版本会重置为 sha 中的版本。
git checkout
另一方面:
当给出 或 --patch 时,git checkout 不会切换
分支机构。它从以下位置更新工作树中的命名路径
索引文件或来自命名文件(最常见的是提交)。
所以当你这样做时git checkout
您将丢失文件中的更改,并且它将被 sha 中文件版本中的任何内容替换,而当您执行混合重置时,只有您的索引将被重置,并且您的工作目录仍将具有您所进行的更改稍后可以根据需要再次进行。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)