diff git 代码实现_Git解决冲突和diff用法

假设这样一个场景,A和B两位同学各自建了两个分支来开发不同的功能,大部分情况下都会尽量互不干扰的,

但是有一个需求A需要改动一个基础库中的一个类的方法,不巧B这个时候由于业务需要也改动了基础库的这个方法。

那么在提交的时候便有可能会出现冲突conflicts

952fdabb52074f9f004b9e73b47004f9.png

一定要记住这个单词,CONFLICT

此时使用 git diff

查看具体冲突

719435b3287e9e16d4bba64f92512875.png

上图就是冲突的示例,

冲突的地方==============分出了上下两个部分,

上半部分 **HEAD** 是当前所在分支的代码

下半部分是别人提交的代码

此时进入代码中把判断哪些代码进行删改,

我们只需要移除掉那些老旧代码,同时也要把那些 <<< HEAD  ==== 以及 >>>>>>baidu_activity 标记符号删除,最后进行一次 commit 就可以了。

diff的用法

diff命令是很常用的,在开发过程中,大家会经常做一些代码改动,但时间久了难免会忘记做过哪些改动,在提交之前需要确认下,这个时候就可以用diff来查看到底做了哪些改动,

例如,有一个 a.md 的文件,做了一些改动,

当输入 git diff 时,

就会看到如下内容:

b6003c3be6a4f9169acc953eec4b0bbd.png

需要注意的是,直接输入 git diff 只能比较当前文件和暂存区文件差异,

什么是暂存区?就是还没有执行 git add 的文件。

当然除了与暂存区做比较之外,他还可以有其他用法,如比较两次 commit 之间的差异,比较两个分支之间的差异,比较暂存区和版本库之间的差异等,具体用法如下:

git diff                  # 比较两次提交之间的差异

git diff ..    # 在两个分支之间比较

git diff --staged                          # 比较暂存区和版本库差异

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值