- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
git checkout COMMIT
将当前状态切换到 COMMIT
指向的状态并重新应用任何未提交的更改(如果您未提交的更改与您要切换到的 COMMIT
不兼容,它甚至会失败。
这个功能与git checkout COMMIT FILE
形成鲜明对比它只是盲目地丢弃所有未提交的更改(没有任何警告)FILE
并“强制”FILE
的状态在COMMIT
.
我的问题是,为什么不一致? (可能与历史/设计决策有关)
当然可以做到 git checkout COMMIT FILE
试图重新应用未提交的更改 FILE
如果失败,则优雅地失败。特别是因为 git checkout
通常被宣传为“安全”操作。如果有的话,git checkout COMMIT FILE
的当前行为应该是 git reset --hard COMMIT FILE
的行为. (附带说明,git reset COMMIT
和 git reset FILE
的行为也为一致性的改进留下了空间...)
最佳答案
git checkout <em>commit</em>
switches your current state to that pointed bycommit
...
是的,有点。实际上,它在幕后要复杂得多。
... and reapplies any uncommitted changes (it even fails nicely if your uncommitted changes are incompatible with the
commit
you want to switch to).
它确实不做第一部分(但做第二部分),这就是并发症:什么 git checkout
正在做的是the git read-tree
documentation calls a two tree merge的一个子集.如果你点击这个链接,你会看到这列出了 21 个单独的案例(一个,案例 #3,有两个子案例,我忽略了不可能发生的案例 #0,所以如果你计算子案例和案例 #0 你得到 23 个不同的案例)。我不会在这里列出它们,但它们可以归结为这个想法:如果 Git 在切换提交时不必触及索引和工作树,它就不会。那是是什么让您未提交的更改保持原样:Git 不会重新应用任何东西,它也不会删除任何东西。它只是轻轻地绕过未提交的更改。
反过来,这在某种程度上(但不完全)解释了这种截然不同的行为,包括我在内的一些人可能会称邪恶:
This functions in stark contrast to
git checkout <em>commit</em> <em>file</em>
which just blindly discards any uncommitted changes (without any warning) offile
and "forces" the state offile
to that incommit
.
是的,这是因为 Git 将您的命令视为替换 file
的索引副本的请求。 来自 commit
。更新后的索引副本也被复制到工作树中。
我认为(过去也曾)认为这应该是一个单独的 Git 命令。它恰好由相同的源代码实现,因为该源代码充满了“从提交中提取文件,写入索引和工作树”的代码。但git reset
也是如此, 和 git reset
是一个单独的命令。1 所以这充其量只是Hysterical Raisins 的一个借口。形式。
Surely it could have been made such that
git checkout <em>commit</em> <em>file</em>
attempted to reapply uncommitted changes tofile
and failed gracefully if that failed.
这也可以在 git checkout
中找到, 在 -m
下选项...有点。但是,它不是基于每个文件,而是仅基于整个提交。也就是说,你可以 git checkout -m <em>commit</em>
,它将您的工作树与目标提交 merge (作为三树 merge ),但不是 git checkout -m <em>commit</em> <em>file</em>
.要获得该效果,请从提交中提取文件,选择要提取的 merge 基础版本,然后使用 git merge-file
关于三个文件:
git show other:file > file.other
git show base:file > file.base
git merge-file file file.base file.other
1Git 的 reset
也将太多不相关的功能塞进一个面向用户的命令中,如果你问我,但你没有。
(On a side note, the behavior of
git reset <em>commit</em>
andgit reset <em>file</em>
also leaves room for improvement in consistency...)
好吧,也许你做到了! :-)
关于git - 为什么 git checkout FILE 不重新应用未提交的更改?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53511125/
这个问题在这里已经有了答案: How does Scala's apply() method magic work? (3 个回答) 9年前关闭。 假设我在 scala 中有一个 MyList 类,其
这个问题在这里已经有了答案: What is a non-capturing group in regular expressions? (18 个回答) Reference - What does
这个问题是针对嵌入式系统的! 我有以下选项来初始化一个对象: Object* o = new Object(arg); 这会将对象放入堆中并返回指向它的指针。我不喜欢在嵌入式软件中使用动态分配。 Ob
我自己搜索过,没能成功的正则表达式。 我有一个 html 文件,其中包含 [] 之间的变量我想把每一个字都写进去。 [client_name][client_company] [cl
我是 Python 新手。我不明白为什么这段代码不起作用: reOptions = re.search( "[\s+@twitter\s+(?P\w+):(?P.*?)\s+]", d
在过去 7 个月左右的时间里,我几乎一直在使用 .NET C# 进行编程。在那之前,我的大部分编程都是用 C++(从学校里学的)。在工作中,我可能需要在接下来的几个月里做一大堆 C 语言。我对 C 的
我是 RE 的新手,我正在尝试获取歌词并分离出歌词标题、和声和主唱: 下面是一些歌词的例子: [Intro] D.A. got that dope! [Chorus: Travis Scott] Ic
这可能是不可能的,但我想检查是否可以用一种简单的方式表达这样的事情: // obviously doesn't work class Foo : IFoo where T: Bar {
我们的应用程序中有“user”和“study”实体,存储在它们各自的表中。一项研究代表一种研究和已收集的数据。它们是多对多的关系,所以我们需要一个链接表:studies_users。 我们为用户分配角
将测试条件添加到 Visual Studio 2010 数据库单元测试(对于 SQL Server 2008)时,这些条件称为例如rowCountCondition1、rowCountConditio
在模拟器上,我可以从设置中卸载 SD 卡。 然后我可以将它安装到我的操作系统上,然后正常卸载它。 我一直无法弄清楚如何在模拟器上重新安装它(无需重新启动)。 提示: adb 命令 remount 是无
假设在一个分支上执行了一系列提交,但该分支尚未与主干重新同步。是否可以从提交中生成全局补丁?是否可以从一系列提交中生成“分组”补丁?如果是,如何? 最佳答案 svn diff -rXXX:YYY UR
在某些情况下,我想在我的应用程序中锁定调整大小功能,为此我尝试对属性进行数据绑定(bind),并且不允许在某些情况下更改它,但没有成功。 有没有办法这样做? 这是我不成功的尝试: XAML: Vie
当我的计算机连接多个显示器时,我可以检测它们,并根据从获取的值设置位置来向它们绘制图形 get(0, 'MonitorPositions') 但是,当我在 MATLAB 运行时断开监视器时,此属性不会
我们有一个grails应用程序,该应用程序在grails数据库中存储了各种域对象。该应用程序连接到第二个数据库,运行一些原始sql,并在表中显示结果。它基本上是一个报告服务器。 我们通过在DataSo
无法比较来自不同容器的迭代器(参见这里的示例: https://stackoverflow.com/a/4664519/225186 )(或者从技术上讲,它不需要有意义。) 这就提出了另一个问题,来自
我有以下情况: 家长 Activity : ParentActivityClass { private Intent intent; @Override public void onCreate(Bu
我经常将元素与附加功能 Hook ,例如: $('.myfav').autocomplete(); $('.myfav').datepicker(); $('.myfav').click(somefu
因此,我将 tooltipster.js 库用于工具提示,并尝试更改工具提示在不同屏幕尺寸上的默认距离。 所以这是默认的 init 的样子: $(inputTooltipTrigger).tool
我在 ARM7 嵌入式环境中工作。我使用的编译器不支持完整的 C++ 功能。它不支持的一项功能是动态类型转换。 有没有办法实现dynamic_cast<>() ? 我使用 Google 寻找代码,但到
我是一名优秀的程序员,十分优秀!