GIT中的暂存区和Stash
Git的一个重要特点是它有一个暂存区,即Index或Stage,刚接触Git的我很疑惑,不理解暂存区的必要性,认为在工作区和版本库之间加了一个暂存区,反而增加了麻烦,随着不断的实践,暂存区的优势慢慢体现出来了。
1. 暂存区的好处
- 分批分段提交
假如你在工作区修改了A、B、C、D四个文件,其中A、B文件和功能一相关,C、D文件和功能二相关,如果功能一已经完成,功能二还未完成,但是这时boss需要将功能一的代码提交,这时我们可以先将A、B文件添加到暂存区中,然后进行提交,C、D文件依然在工作区中进行操作,等功能二也完成后,再进行提交。 - 方便进行快照回退
如果我们对于工作区的修改不满意,可以将工作区的内容恢复到暂存区的状态,使用代码git checkout fileName
。
2. 关于Stash
Stash使用场景:当前你在分支develop上工作,但工作还未完成,这时有一个紧急任务需要你做,这时需要新建一个新的分支emergency处理你的紧急任务,但develop分支上的工作未做完不想提交,为了不使develop分支上的工作和emergency分支上的工作产生混乱,我们可以将develop分支上的内容隐藏起来,等emergency上的工作完成之后再将隐藏的内容恢复出来。而Stash可以实现工作区和暂存区内容的隐藏和恢复。
git stash
/git stash save message
/git stash push message
将工作区和暂存区内容隐藏起来,参数message
为注释信息,方便查找,可以进行多次stash,每次的隐藏内容存储在一个栈中。git stash list
列出栈中的所有内容。git stash show stash@{num}
显示某个隐藏的具体内容。git stash pop
/git stash apply stash@{num}
调用某个隐藏内容,pop
和apply
的区别是:pop
取出栈中的第一个内容,且删除栈中的记录,apply
可以调用任意一个隐藏内容,但是并没有删除栈中的记录。git stash drop stash@{num}
删除栈中的某个记录。git stash clear
删除栈中的所有记录。