描述:首先刚到公司从公司gitlab上直接把download到了本地 在上面进行熟悉代码 更改了点东西;但是后来发现写的东西后面能用到,就想着推送到dev分支,但是推送之前要先在idea中pull到dev的代码(这个原因自查),可是发现不管是pull还是merge都会报错误refusing to merged unrelated histories,可能是它们两个版本没有关系的原因,不太清楚。
解决方法:通过查阅大量资料、验证发现一条正确方法;
1.首先打开你的git bash客户端,进入到你的项目目录,或者直接在你的项目目录中打开git bash;
然后输入git pull origin xxx --allow-unrelated-histories (xxx 是远程的分支)
2.可能会报一个错误:error:“Your local changes to the following files would be overwritten by checkout”
这时有两种解决方法:
方法一、stash
1 git stash 2 git commit 3 git stash pop
接下来diff一下此文件看看自动合并的情况,并作出相应修改。
git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。
方法二、放弃本地修改,直接覆盖
1 git reset --hard
2 git pull origin xxx --allow-unrelated-histories
我用的是第二种方法;
这样就把你要合并的分支的内容合并成功。