常用命令
命令 | 含义 |
---|---|
stash 或 stash save | 新建储藏 |
stash list | 列出所有的储藏 |
stash apply <name> | 恢复指定储藏,若不指定 name,则使用最新储藏 |
stash apply --index | 恢复储藏,同时恢复暂存状态的文件 |
stash drop <name> | 删除掉指定的储藏 |
stash pop <name> | 应用储藏并从栈上删除指定的储藏 |
stash bransh <name> | 创建新分支。同时将储藏应用到新旧分支上 |
drop 与 pop 的区别在于:pop 会应用储藏,同时将其删除;而 drop 只是删除储藏。pop 类似于 drop 与 apply 的结合。
基础
stash 主要用于将未完成的修改保存到一个栈中。在必要的时候重新运用这些修改。
-
想要切换分支,但又不想将当前的修改进行提交,可以将当前的修改进行储藏(stash)。
-
储藏不但会储藏工作目录中修改的文件,还会储藏已暂存的文件。
-
可以将一个分支的储藏应用到另一个分支中。
-
如果文件已经发生修改,则应用储藏时会发生合并操作。如果发生冲突,需解决冲突。
-
恢复储藏时,并不能将已暂存的文件恢复到已暂存状态。但可以使用
git stash apply --index
恢复暂存状态的文件。如:$ git stash apply --index stash@{0} On branch dev Changes to be committed: (use "git reset HEAD <file>..." to unstage) modified: aa Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git checkout -- <file>..." to discard changes in working directory) modified: bb modified: i/i.txt modified: test.html modified: xxx.xxx
可以看出,使用 --index 选项后,被暂存过的文件在恢复后依旧处于暂存状态。
save
新建储藏。
选项 | 含义 |
---|---|
--keep-index | 不储藏暂存区中的修改 |
--include-untracked 或 -u 选项 | 储藏包含未跟踪的文件 |
--patch 或 -p | 进入交互模式 |
-
默认情况下,新建的储藏包含暂存区与工作目录中所有的修改。
-
使用 --keep-index 只会暂存工作目录中的修改,已经添加到暂存区中的文件不会被储藏。
$ git stash save --keep-index Saved working directory and index state WIP on dev: d84b24d a HEAD is now at d84b24d a $ git status On branch dev Changes to be committed: (use "git reset HEAD <file>..." to unstage) modified: aa
使用命令后,aa 文件依旧处于暂存状态。在不使用时,新建后整个工作区间应该是干净的。
-
使用 -u 选项后,未跟踪的文件也会被储藏。而默认情况下,这些文件会被忽略。
$ git stash -u Saved working directory and index state WIP on dev: d84b24d a HEAD is now at d84b24d a $ git status On branch dev nothing to commit, working directory clean
使用 -u 命令后,整个工作空间非常干净,连未跟踪的文件都被储藏。
-
使用 -p 或 --patch 进行交互模式后,其操作与
git add -p
一样。只不过 add 是对选择的块进行暂存,而 stash 是选择对指定的块进行储藏。
stash branch
在创建储藏的分支处创建新的分支,同时将储藏应用到新分支中。如果命令执行成功,则会删除旧有储藏。
-
创建新分支时,储藏依旧会应用到旧分支上。也就是说命令执行完毕后,新旧分支没有任何差别。
-
如果只想将储藏应用于新分支,可以先通过
git branch <name>
创建一个新分支,再切换到对应的分支上,最后在新分支上使用git stash apply
应用指定的储藏。
clean
移除工作区间中的一些文件或目录
-
clean
清除的文件有可能无法找回,应谨慎使用。可以使用git stash --all
移除每一样东西,同时将这些东西存储于栈中。 -
使用
git clean -f -d
移除工作目录中所有未追踪的文件以及空的子目录。 -
使用
git clean -n
输出git clean
将要执行的操作,但并不会执行。$ git clean -n Would remove bbb
它会告诉你将要移除 bbb 文件,但实际上并没有移除。只有再次运行
git clean
时才会移除。 -
默认情况下,git clean 命令只会移除没有忽略的未跟踪文件。 任何与 .gitiignore 或其他忽略文件中的模式匹配的文件都不会被移除。
网友评论