git学习小计(三):git diff

在了解了git中的工作区、暂存区、版本库的概念后,git diff命令就容易理解了,git diff会根据不同的参数,对工作区、暂存区和HEAD版本库进行两两比较。



1、git diff:工作区和暂存区比较

2、git diff --cached:暂存区和HEAD比较

3、git diff HEAD:工作区和HEAD比较


顺便记下今天遇到的一个问题:

从一个分支A切换到另一个分支B后,对切换后的B分支进行pull操作,因为pull操作实际上包含了fetch+merge操作,在执行merge操作时,由于很长时间没有对B分支执行过pull/merge操作,本地的B分支库与remote中的B分支库中的差异很大(且这些差异是其他同事开发的文件),merge时产生冲突,使得B分支的状态为merging,其实是指merge失败,还停留在merge状态,也不能执行pull操作。这时没有解决冲突,而是从B分支上执行checkout/switchto操作,试图再切换其他分支时,报:

…….java : needs merge
…….java : needs merge
…….java : needs merge
error : you need to resolve your current index first
的错,google了半天,终于在stackoverflow上找到了答案,大题意思是:merge失败,有conflicts没解决,可以:

1、解决conflicts后再次执行merge;

2、回退到merge前

恩,既然merge冲突是其他同事的文件,我不需要去resolve conflicts,那就退回merge前吧,单纯的改我的文件再push吧,执行以下代码:

git reset --merge
搞定!

顺便贴下stackoverflow上的链接:

http://stackoverflow.com/questions/6006737/git-merge-errors


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值