idea git解决冲突,绝对经典

摘要

提交代码时: 首选需要拉取(pull)线上(远程仓库)得最新代码

当本地有更改得时候,首先明确拉取(pull)代码得两种方式:
1. 直接拉取(pull)代码 右键项目-> git->repository->pull
2. 先将代码提交到本地库中,在拉取代码(pull)

	 - 右键项目->git ->commit : 先将修改得代码提交到本地库中
	 - 右键项目-> git->repository->pull :在拉取(pull)远程仓库得代码

当作此操作时,可能会与线上代码冲突,这时针对于上述两种操作,会呈现出两种不同解决冲突得方式。
假设本地代码与线上代码冲突:

1. 针对直接pull 代码,再commit得操作,解决冲突得办法:

pull的时候我们会发现右下角有提示说pull failed(这是肯定的啦,因为我们代码冲突了嘛)
在这里插入图片描述
这时使用 Stash Changes 和 unStash Changes 来解决冲突。

  • Stash Changes :
    作用:本地的全部改动临时保存到本地仓库,并撤销了本地的所有改动
    stash的好处是,可以先将你的改动暂存到本地仓库中,随时可以取出来再用,但是不用担心下次push到服务器时,把不想提交的改动也push到服务器上,因为Stash Changes的内容不参与commit和push。
  • unStash Changes
    作用:将之前保存得临时改动,取出并合并带本地。

具体操作步骤如下:

  • (1)我们选择项目右键–Git–Repository–Stash Changes

在这里插入图片描述
在这里插入图片描述
在Message中随便取个名字,然后点击Create Stash。
以上几步的操作,其实就是把你在本地做的改变,通过stash先在git栈中保存起来(因为你没有commit嘛,对比先commit再pull,你会发现 先commit再pull会比较方便,(commit操作就是类似于把改变先存起来吧。。个人理解、、))。

stash完后你会发现你本地进行的一些修改都已经不存在了,这样我们就可以和远程仓库合并了,(我们已经把冲突先去掉了)。git pull 顺利成功。

  • (2)我们选择项目右键–Git–Repository–pull
    将线上得代码拉取到本地

  • (3)现在我们再把之前保存的更改取出来 选择项目右键–Git–Repository–UnStash Changes
    在这里插入图片描述
    选择刚刚我们命名的那个更改记录,我这里就是第一个。

然后我们点Apply Stash,来到如下窗口,提示有代码冲突
在这里插入图片描述

  • (4)合并冲突
    我们直接选择Merge
    在这里插入图片描述
    然后我们点击Apply,把冲突解决。别忘了commit和push。

2 针对先commit本地,再pull得操作,解决冲突得办法:

  • (1)先commit 再pull
    pull的时候会提示有冲突,需要你进行手动merge
    在这里插入图片描述
    Accept Yours 就是直接选取本地的代码,覆盖掉远程仓库的
    Accept Theirs 是直接选取远程仓库的,覆盖掉自己本地的
    我们选择Merge,自己手动行进选择、修改。
    在这里插入图片描述
    这里左边部分是你本地仓库的代码,右边部分是远程仓库的代码,中间的result就是你修改之后的结果。左下角的Accept Left 和Accept Right其实就相当于是之前的 Accept Yours 和 Accept Theirs 右下角的Apply是确认合并,Abort是取消合并。

我们在result中修改好自己想要merge的代码,然后点击Apply。
在这里插入图片描述
点yes.

这样我们就解决了冲突,解决完冲突后记得要再commit一次,分别更新本地和远程仓库的代码.

3. 最后说下stash chage 使用得注意事项

有时候,你还没完成工作,不想提交,但又有新任务,必须切换到另一个分支,就用stash
“‘储藏”“可以获取你工作目录的中间状态——也就是你修改过的被追踪的文件和暂存的变更——并将它保存到一个未完结变更的堆栈中,随时可以重新应用。
注意事项
需注意上面那句话所对作用范围的定义,如果你的文件没add,即没有“被跟踪”和“暂存”,stash是不会帮你保存的
例如,我增加了两个文件Readme,readme,我并没有git add这两个新文件,然后输入以下命令

Dark@Dark-laptop:~/box_4.2$ git stash

会提示:

No local changes to save

表明stash

  • 10
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个小虾米

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值