git 冲突的解决

如果不小心commit了一个不需要commit的文件,可以对其进行撤销。 

先使用git log 查看 commit日志

  1. commit 422bc088a7d6c5429f1d0760d008d86c505f4abe  
  2. Author: zhyq0826 <zhyq0826@gmail.com>  
  3. Date:   Tue Sep 4 18:19:23 2012 +0800  
  4.   
  5.     删除最近搜索数目限制  
  6.   
  7. commit 8da0fd772c3acabd6e21e85287bdcfcfe8e74c85  
  8. Merge: 461ac36 0283074  
  9. Author: zhyq0826 <zhyq0826@gmail.com>  
  10. Date:   Tue Sep 4 18:16:09 2012 +0800  

找到需要回退的那次commit的 哈希值,

git reset --hard commit_id 

 使用上面的命令进行回退

 

    根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:
    git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息
    git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
    git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容

HEAD 最近一个提交
    HEAD^ 上一次
    <commit_id> 每次commit的SHA1值. 可以用git log 看到,也可以在页面上commit标签页里找到


    git reset --hard <commit_id>

    git push origin HEAD --force

关于冲突解决:

方案1

如果在git pull的时候已经冲突了,可以

git stash

git pull

git stash pop

来解决,通过stash缓存本地代码,然后git pull下载远端代码,之后git stash pop,如此有冲突的文件就会合并,需要手动解决一些冲突的地方。之后再git add

git commit ..

git push

正常提交。

方案2:

第二种思路,先reset到远端的head,之后重新提交本地代码,也同样可以解决冲突,由于git使用的是快照存储,而不是增量存储,这样也相当于覆盖了旧的代码。这个在eclipse中用插件操作比较方便。

git reset origin/master 慎用!

方案3:

如果pull的时候冲突

则先:add commit

后:pull

代码会自动合并,如果自动合并失败,则去手动合并,

之后再次add commit push



To ssh://ming.liu@10.1.122.185:29418/rcs-server.git
 ! [remote rejected] master -> master (you are not allowed to upload merges)

上述问题可以用rebase解决

git参考:

http://gitbook.liuhui998.com/index.html


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

day walker

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

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

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

打赏作者

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

抵扣说明:

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

余额充值