git解决代码提交冲突

摘要:
树冲突文件名修改造成的冲突,称为树冲突。对于git来讲,编辑冲突跟平时的修改代码没什么差异。然后执行下面命令继续rebase:gitrebase--continue有冲突继续解决,重复这这些步骤,直到rebase完成。执行gitmergetool用预先配置的BeyondCompare解决冲突:界面三个窗口依次是“LOCAL”、“BASE”、“REMOTE”,它们只是提供解决冲突需要的信息,是无法编辑的。

树冲突
文件名修改造成的冲突,称为树冲突。
比如,A同事把文件改名为A.C,B同事把同一个文件改名为B.C,那么B同事将这两个commit合并时,会产生冲突。
如果最终确定用B同事的文件名,那么解决办法如下:
git rm A.C
git rm origin-name.C
git add B.C
git commit
如果最终确定用A同事的文件名,那么解决办法如下:
git rm B.C
git rm origin-name.C
git add A.C
git commit
内容冲突(git pull拉取最新代码发现)
一般来讲,出现冲突时都会有“CONFLICT”字样,特别的直接报错repo sync的报错,可能并不是直接提示冲突
现在,需要进入报错的项目(git库)目录,然后执行git rebase解决:
git rebase remote -branch-name
冲突解决的一般步骤
merge/patch的冲突解决
先编辑冲突,然后git commit提交。
对于git来讲,编辑冲突跟平时的修改代码没什么差异。修改完成后,都是要把修改添加到缓存,然后commit。
rebase的冲突解决
rebase的冲突解决过程,就是解决每个应用补丁冲突的过程。
解决完一个补丁应用的冲突后,执行下面命令标记冲突已解决(也就是把修改内容加入缓存)
git add -u -u 表示把所有已track的文件的新的修改加入缓存,但不加入新的文件。
然后执行下面命令继续rebase:
git rebase --continue
有冲突继续解决,重复这这些步骤,直到rebase完成。
如果中间遇到某个补丁不需要应用,可以用下面命令忽略
git rebase --skip
如果想回到rebase执行之前的状态,可以执行:
git rebase --abort
注:rebase之后,不需要执行commit,也不存在新的修改需要提交,都是git自动完成。
直接编辑冲突文件:
冲突标记<<<<<<< (7个<)与=======之间的内容是我的修改
=======与>>>>>>>之间的内容是别人的修改
最简单的编辑冲突的办法,就是直接编辑冲突了的文件(test.txt),把冲突标记删掉,把冲突解决正确。
此时,还没有任何其它垃圾文件产生。
利用图形界面工具解决冲突
如果要解决的冲突很多,且比较复杂,图形界面的冲突解决工具就显得很重要了。
执行git mergetool用预先配置的Beyond Compare解决冲突:
界面三个窗口依次是“LOCAL”、“BASE”、“REMOTE”,它们只是提供解决冲突需要的信息,是无法编辑的。
下面一个窗口是合并后的结果,可以手动修改,也可以点击相应颜色的箭头选择“LOCAL”或者“REMOTE”。
在Beyond Compare中修改冲突保存后,冲突文件(test.txt)中的冲突标记就没有了,成了修改后的内容,一个文件的冲突编辑就完成了。
注意:启动Beyond Compare之后,会自动生成几个包含大写字母名称、数字的辅助文件
关闭Beyond Compare时,这几个辅助文件都会自动删除,但同时会生成一个test.txt.orig的文件,内容是解决冲突前的冲突现场。
默认该.orig文件可能不会自动删除,需要手动删掉!!!!

免责声明:文章转载自《git解决代码提交冲突》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇linux-基础命令用户使用VPS的12个常见问题下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

git日志的查看与修改

1.命令行中查看日志git log 默认是显示所有的日志信息,之前出来的界面显示的日志,很少。 最后发现,只需要使用键盘上向下键↓,就可以继续浏览更多的日志 空格键,可以翻页浏览日志。  向左←  向右 →  的箭头,可以水平移动查看日志 2.将日志按照格式导出到文件中git log --pretty=format:'%h was %an, %ar, me...

Git 命令速查

一般来说,日常使用只要记住下图6个命令,就可以了。但是熟练使用,恐怕要记住60~100个命令。 下面是我整理的常用 Git 命令清单。几个专用名词的译名如下。 Workspace:工作区 Index / Stage:暂存区 Repository:仓库区(或本地仓库) Remote:远程仓库 一、新建代码库 # 在当前目录新建一个Git代码库 $ g...

git学习(三)

Git学习(三)——使用Git协同开发 项目协同开发git操作 基本流程 1.开发前,拉一次远程仓库 2.工作区进行开发 3.将开发结果提交到本地仓库 git status 查看时没有待处理的事件 4.拉取远程仓库(每一次要提交远程仓库前必须先拉) 5.如果出现冲突,线下沟通(协商重新开发冲突文件),处理后继续重复 3,4 两步过程 6.没有冲突后,提交...

Jenkins代码自动部署相关文档

环境 centos 7.0+ Java JDK 1.8+ jenkins 2.220 maven 3.0+ git 1.8+ 注意事项 一. linux 安装 JDK (jdk-8u201-linux-x64.tar.gz) 1.下载jdk 2.在/usr 目录下,新建 /java 目录, 3.在/java 目录下,新建/jdk目录, 4.把jdk-...

git命令行提交流程

一、顺利提交无冲突情况(diff->add->fetch->pull->commit->push) 1.git  status 查看状态    2. git diff head 比较当前工作区与版本库的不同 3. git add -A  确认无误后增加到暂存区 4.git fetch origin 更新远程仓库,从分支上拉取信...

全网最详细的Git学习系列之介绍各个Git图形客户端(Windows、Linux、Mac系统皆适用ing)(图文详解)

     不多说,直接上干货! 一、TortoiseGit - The coolest Interface to Git Version Control   TortoiseGit 是 TortoiseSVN 的 Git 版本,TortoiseGit 用于迁移 TortoiseSVN 到 TortoiseGit,一直以来 Git 在 Windows 平台没...