GIT中的暂存区

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可以实现工作区和暂存区内容的隐藏和恢复。

  1. git stash / git stash save message / git stash push message
    将工作区和暂存区内容隐藏起来,参数 message 为注释信息,方便查找,可以进行多次stash,每次的隐藏内容存储在一个栈中。
  2. git stash list
    列出栈中的所有内容。
  3. git stash show stash@{num}
    显示某个隐藏的具体内容。
  4. git stash pop / git stash apply stash@{num}
    调用某个隐藏内容,popapply 的区别是:pop 取出栈中的第一个内容,且删除栈中的记录, apply 可以调用任意一个隐藏内容,但是并没有删除栈中的记录。
  5. git stash drop stash@{num}
    删除栈中的某个记录。
  6. git stash clear
    删除栈中的所有记录。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值