git stash
首先,git stash的含义是将修改的代码先暂存起来,让本地仓库回到最后一次提交时的状态,便于代码的更新管理,主要避免修改文件与最新代码的冲突。
应用场景
场景一
当正在dev分支上开发某个项目,这时项目中出现一个bug,需要紧急修复,但是正在开发的内容只是完成一半,还不想提交,这时可以用git stash命令将修改的内容保存至堆栈区,然后顺利切换到hotfix分支进行bug修复,修复完成后,再次切回到dev分支,从堆栈中恢复刚刚保存的内容。
场景二
由于疏忽,本应该在dev分支开发的内容,却在master上进行了开发,需要重新切回到dev分支上进行开发,可以用git stash将内容保存至堆栈中,切回到dev分支后,再次恢复内容即可。
总的来说,git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。
这也就是说,stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。
git stash作用的范围包括工作区和暂存区中的内容,也就是说没有提交的内容都会保存至堆栈中。 但是没有在git 版本控制中的文件,是不能被git stash 存起来的命令
git stash 和git stash pop是最基础的命令,还有
git stash save ‘保存的信息’ 其实和git stash的作用是一样的,
塞进的信息便于理解stash条目的内容
git stash list 展示出所有stash信息的列表,左边标题的形式是stash@{n}
git show stash@{n} 展示指定的stash中的某一条的信息
git stash drop 这个命令是要丢弃掉最新的一个stash条目,等同于git stash drop stash@{0}~~~~