git解决代码提交冲突

树冲突
文件名修改造成的冲突,称为树冲突。
比如,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的文件,内容是解决冲突前的冲突现场。

原文地址:https://www.cnblogs.com/liurwei/p/9414121.html

时间: 2024-09-29 07:49:26

git解决代码提交冲突的相关文章

Eclipse svn代码提交冲突

Eclipse svn代码提交冲突(转) 1.Synchronize视图下查看代码冲突 1.Incoming Mode 全部update,更新到本地2.Outgoing Mode 全部commit,提交到代码库3.Confilcts Mode 解决冲突,另存.对比.Override and Update.修改.Commit 2.解决简单的文件版本冲突 对于产生版本冲突的文件,如果两个人改动的不是同一处位置,例如成员A只改动了文件头部,成员B只改动了文件的尾部,那么无需过多担心,因为现在的SVN已

git解决代码冲突

1.当项目开发是几个人的时候,难免会出现代码冲突,使用git命令行解决冲突的方法如下: git checkout develop git pullgit checkout feature/新建会员功能git merge develop 将develop merge到 分支上git status 查看状态在ide下解掉冲突 :wq git add web-app/source/app/胜利iews/member/students.html 冲突的文件git commitgit push origi

SVN版本号管理工具使用中常见的代码提交冲突问题的解决方法

相信刚開始学习使用SVN的小伙伴在项目合作开发的过程中一定常常遇到一些影响到自己编写的代码的苦恼.我这里列举了几种常见的问题以及问题的解决方法: 1.误删除和误操作的问题 问题1:有A和B两个人一块合作写项目的时候,B在写代码的时候不小心更改了A写的代码文件的内容提交到了仓库,A该怎样找回自己原来的代码呢? 解决方法: 右键点击被改动的文件---->点击TortoiseSVN选项----->点击Show log选项,会出现如图所看到的的窗体, watermark/2/text/aHR0cDov

SVN版本管理工具使用中常见的代码提交冲突问题的解决方法

相信刚开始学习使用SVN的小伙伴在项目合作开发的过程中一定经常遇到一些影响到自己编写的代码的苦恼,我这里列举了几种常见的问题以及问题的解决方法: 1.误删除和误操作的问题 问题1:有A和B两个人一块合作写项目的时候,B在写代码的时候不小心更改了A写的代码文件的内容提交到了仓库,A该如何找回自己原来的代码呢? 解决方法: 右键点击被修改的文件---->点击TortoiseSVN选项----->点击Show log选项,会出现如图所示的窗口, 然后右键点击A的记录--->点击Revert t

ubuntu16系统中pycharm下使用git将代码提交到github仓库

1 在系统中安装git,在terminal中输入以下命令 sudo apt-get update sudo apt-get install git 2 对git进行配置,在terminal中输入以下命令 git config --global user.name "Your Name" git config --global user.email "[email protected]" 使用以下命令可以看到刚才的配置 git config --list 3 对pyc

有关git的使用,和git的一些提交冲突。

git 的一些基本用法 git init :初始化文件(创建文件夹). git add . :监控工作区的状态树(将被修改的文件提交到暂存区) git status :未跟踪状态(Untracked)git add命令将文件提交到暂存区.   (changes to be committed)表示文件已经位于暂存区处于可以提交的状态. git commit -m'' :将修改从暂存区提交到本地版本库 git push origin master :基本格式 git push <远程主机名> &

git:将代码提交到远程仓库(码云)

初始化 进入一个任意的文件夹(如D:\aqin_test1\) git init git config 邮箱 git config 姓名 git remote add origin https://gitee.com/aqin1012/aqin_test1.git # 远程上传地址( https://gitee.com/aqin1012/aqin_test1.git目标保存地址,根据自己实际情况进行修改) (此时git已经将D:\aqin_test1\目录管理起来,即此后此文件夹有任何变化,gi

解决idea提交冲突的问题

1.解决冲突 选择OK: 弹窗如下: 如果选择Merge…,则弹出版本差异的窗口,让用户自行查看差异后再选择以哪个版本的修改为准: 2.更新到指定版本 右键工程: 选中其中一个版本后点击ok即可. 参考:https://blog.csdn.net/zhuyi2576947717/article/details/82714058 https://www.cnblogs.com/a8457013/p/7779135.html 原文地址:https://www.cnblogs.com/maigy/p/

Git中使用amend解决提交冲突

问题描述       场景:当你提交的时候,发现跟要合并的流有冲突,你需要解决完冲突再次提交. 如果在SVN时代,你可以直接在本地解决完冲突再提交就可以了,因为SVN会把正确的代码先提交到服务器,至于有冲突的代码,你需要在本地解决完冲突再提交. 但在Git中这样做行不通,Git中每次提交都是完整的,也就是说,即使你这次提交有中冲突的代码,它也一并会推送到要合并的流,每次提交会有一个change_id,当你解决完冲突提交后,这个change_id又会发生变化.这样导致的直接后果是:由于Git是由提