关于作者

Discuss / Git / 这里对`--`(double dash)的解读不够正确

这里对`--`(double dash)的解读不够正确

问题来源

大熊原子笔

#1 Created at ...

git checkout -- file命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令,我们在后面的分支管理中会再次遇到git checkout命令。

原文上面的表述不够严谨,去掉 -- 使用 git checkout file 并不会变成切换分支,起到的效果仍然是,还原工作区的file文件内容。

解答 -- 是什么意思,不妨先看它的前世今生。

-- 的名称叫做double dash,是bash的内置命令,用来标记可选命令选项的结束。即在它后面的带 -- 的字符串,不被当做是一个命令选项。

More precisely, a double dash (--) is used in bash built-in commands and many other commands to signify the end of command options, after which only positional parameters are accepted.

举例: 在 grep 命令中 -V 原本是一个可选的命令参数(options),打印出 grep 命令的版本。

但结合--后,以下命令表示在 d1.txt 文件中查找 "-V" 字符串 grep -- -V d1.txt

Git 的一些命令中,借鉴了这种用法。使用 -- 去隔离开“树”与“路径”。

例如,你想还原 一个文件 path/to/file.txt,在Git中使用如下命令

git checkout path/to/file.txt

但是天杀的居然有一个文件名字就叫做 "master" 如果你套用上面的命令,想还原“master”文件

git checkout master

最终起的效果是变成切换到了master分支上。

正确的做法是使用 --,这样它后面的字符串不会当做“树”,而认为是文件路径。

git checkout -- master


  • 1

Reply

WARNING: You are using an old browser that does not support HTML5. Please choose a modern browser (Chrome / Microsoft Edge / Firefox / Sarafi) to get a good experience.