美文网首页
stash 与 clean

stash 与 clean

作者: 一江碎月 | 来源:发表于2018-03-22 13:48 被阅读0次

常用命令

参考

命令 含义
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 主要用于将未完成的修改保存到一个栈中。在必要的时候重新运用这些修改。

  1. 想要切换分支,但又不想将当前的修改进行提交,可以将当前的修改进行储藏(stash)。

  2. 储藏不但会储藏工作目录中修改的文件,还会储藏已暂存的文件。

  3. 可以将一个分支的储藏应用到另一个分支中。

  4. 如果文件已经发生修改,则应用储藏时会发生合并操作。如果发生冲突,需解决冲突。

  5. 恢复储藏时,并不能将已暂存的文件恢复到已暂存状态。但可以使用 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 进入交互模式
  1. 默认情况下,新建的储藏包含暂存区与工作目录中所有的修改。

  2. 使用 --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 文件依旧处于暂存状态。在不使用时,新建后整个工作区间应该是干净的。

  3. 使用 -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 命令后,整个工作空间非常干净,连未跟踪的文件都被储藏。

  4. 使用 -p 或 --patch 进行交互模式后,其操作与 git add -p 一样。只不过 add 是对选择的块进行暂存,而 stash 是选择对指定的块进行储藏。


stash branch

在创建储藏的分支处创建新的分支,同时将储藏应用到新分支中。如果命令执行成功,则会删除旧有储藏。

  1. 创建新分支时,储藏依旧会应用到旧分支上。也就是说命令执行完毕后,新旧分支没有任何差别。

  2. 如果只想将储藏应用于新分支,可以先通过 git branch <name> 创建一个新分支,再切换到对应的分支上,最后在新分支上使用 git stash apply 应用指定的储藏。


clean

移除工作区间中的一些文件或目录

  1. clean 清除的文件有可能无法找回,应谨慎使用。可以使用 git stash --all 移除每一样东西,同时将这些东西存储于栈中。

  2. 使用 git clean -f -d 移除工作目录中所有未追踪的文件以及空的子目录。

  3. 使用 git clean -n 输出 git clean 将要执行的操作,但并不会执行。

    $     git clean -n
    Would remove bbb
    

    它会告诉你将要移除 bbb 文件,但实际上并没有移除。只有再次运行 git clean 时才会移除。

  4. 默认情况下,git clean 命令只会移除没有忽略的未跟踪文件。 任何与 .gitiignore 或其他忽略文件中的模式匹配的文件都不会被移除。

相关文章

网友评论

      本文标题:stash 与 clean

      本文链接:https://www.haomeiwen.com/subject/lgraqftx.html