Skip to content

Latest commit

 

History

History
92 lines (57 loc) · 3.44 KB

Git新功能:switch、restore.md

File metadata and controls

92 lines (57 loc) · 3.44 KB

这篇文章将介绍git restoregit switch两个命令。

想要了解为什么新增了git restoregit switch命令,需先介绍下git checkout命令。

如果你对git还不了解,可以查看我的另一篇文章:教你系统学习Git

1. git checkout

1.1 切换分支

git checkout的功能根据上下文决定,这一点经常让新手感到疑惑。

git checkout经常用来切换本地分支,即切换HEAD指向的分支。例如,从main分支切换到develop分支。

git checkout develop

也可以让HEAD指针指向指定的提交,而非一个分支。此时,会进入分离分支状态(detached HEAD state)。

git checkout 175b4f9d037d022b81dde5bdce3b2d536b1f8dcc

1.2 恢复文件

当为git checkout参数添加文件时,事情开始变得奇怪起来。它会舍弃本地修改,使用分支状态替换。例如,切换到dev分支后对test.txt文件做了一些修改,你可以使用当前分支最后提交中test.txt文件替换当前文件,即恢复到指定提交中的状态。

git checkout -- test.txt

查看git checkout文档,会发现该命令还有一个常被忽略的参数:

git checkout <tree-ish> -- <pathspec>

<tree-ish>代表很多不同的东西,但最常见的是代表提交哈希和分支名。默认为当前分支,但也可以是任意分支、任意提交。

因此,当前在dev分支,想要将test.txt文件改变为main分支的版本,可以使用以下命令:

git checkout main -- test.txt

总结来看,给git checkout命令传递分支、提交作为参数,它会把所有文件修改到指定版本状态;如果指定了文件名称,它只会修改指定文件到指定版本。

2. git switch

虽然上面部分已经介绍了git checkout的使用细节,但确实很容易让新手产生疑惑。git 2.23版本引入了两个新的命令:git switchgit restore,每个命令只做git checkout的一部分工作。git checkout仍然可以使用,但这两个命令对新手更友好。

git switch用来切换分支或提交。

git switch dev

使用git checkout时,可以传入提交,切换到 detached HEAD 状态。git switch默认不支持此操作,需提供-d标记:

git switch -d 175b4f9d037d022b81dde5bdce3b2d536b1f8dcc

另一点不同是,使用git checkout把创建、切换合并到一个命令时,使用-b标记:

git checkout -b new_branch

使用git switch创建并切换到新分支,使用-c标记:

git switch -c new_branch

3. git restore

git checkout传递文件切换文件状态部分功能由git restore实现。使用git restore命令可以把文件恢复到指定状态:

git restore -- test.txt

如果指定了 path,但 restore source 中不存在,则会移除文件以达到和指定版本一致的状态。

参考资料:

  1. New in Git: switch and restore
  2. git-switch - Switch branches
  3. git-restore - Restore working tree files