stash 与 clean

常用命令

参考

命令 含义
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 或其他忽略文件中的模式匹配的文件都不会被移除。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354