站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        git怎么解決合并沖突

        git解決合并沖突的方法:1、編輯有沖突的文件,并刪除文件中的特殊符號(hào),根據(jù)需求修改代碼;2、將指定文件添加到暫存區(qū),并將指定的分支提交到主干,執(zhí)行提交即可,其中使用“git commit”命令時(shí)不能帶文件名, 加文件名會(huì)報(bào)錯(cuò)。

        git怎么解決合并沖突

        本文操作環(huán)境:Windows10系統(tǒng)、Git2.30.0版、Dell G3電腦。

        git怎么解決合并沖突

        git沖突

        多個(gè)分支代碼合并到一個(gè)分支時(shí),兩個(gè)分支中修改了同一個(gè)文件,不管是什么地方修改,都會(huì)產(chǎn)生;

        還有一種 兩個(gè)分支中修改了同一個(gè)文件的名稱時(shí)會(huì)產(chǎn)生。

        原因

        合并分支時(shí),兩個(gè)分支在同一個(gè)文件有兩套完全不同的修改。Git 無(wú)法替

        我們決定使用哪一個(gè)。必須人為決定新代碼內(nèi)容。

        解決方法

        編輯有沖突的文件,刪除特殊符號(hào),決定要使用的內(nèi)容

        添加到暫存區(qū)

        執(zhí)行提交(注意:此時(shí)使用 git commit 命令時(shí)不能帶文件名, 加文件名會(huì)報(bào)錯(cuò),成功提交后,merging消失)

        示例如下:

        1、沖突的產(chǎn)生

        1.1、主干分支代碼

        在主干分支有兩個(gè)文件

        main.cpp

        #include <stdio.h> #include <string.h>  int main() { 	char data[100] = "my branch name is master"; 	int length = strlen(data); 	 	for(int i = 0; i < length; i++) 	{ 		printf("%c", data[i]); 	} 	 	printf("branch mastern"); 	 	return 0; }

        README.md

        this is master branch

        這個(gè)時(shí)候tom和jack分別拉取了主干分支的代碼,并進(jìn)行了修改。

        1.2、tom修改代碼提交合并

        tom創(chuàng)建A分支并對(duì)文件做了以下修改

        main.cpp

        #include <stdio.h> #include <string.h>  int main() { 	char data[100] = "my branch name is A"; 	int length = strlen(data); 	 	for(int i = 0; i < length; i++) 	{ 		printf("%c", data[i]); 	} 	 	printf("branch AAAn"); 	 	return 0; }

        README.md

        this is AAA branch

        提交代碼并合并到主干

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (A) $ git add .  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (A) $ git commit -m "A分支代碼提交" [A ccb2626] A分支代碼提交  2 files changed, 3 insertions(+), 3 deletions(-)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (A) $ git push origin A Enumerating objects: 7, done. Counting objects: 100% (7/7), done. Delta compression using up to 12 threads Compressing objects: 100% (2/2), done. Writing objects: 100% (4/4), 376 bytes | 376.00 KiB/s, done. Total 4 (delta 1), reused 3 (delta 1), pack-reused 0 remote: Powered by GITEE.COM [GNK-6.2] remote: Create a pull request for 'A' on Gitee by visiting: remote:     https://gitee.com/lingpe/kaol/pull/new/lingpe:A...lingpe:master To https://gitee.com/lingpe/kaol.git  * [new branch]      A -> A  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (A) $ git checkout master Switched to branch 'master' Your branch is up to date with 'origin/master'.  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (master) $ git merge A Updating 40c0115..ccb2626 Fast-forward  README.md | 2 +-  main.cpp  | 4 ++--  2 files changed, 3 insertions(+), 3 deletions(-)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (master) $ git push origin master Total 0 (delta 0), reused 0 (delta 0), pack-reused 0 remote: Powered by GITEE.COM [GNK-6.2] To https://gitee.com/lingpe/kaol.git    40c0115..ccb2626  master -> master  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/tom/kaol (master) $

        1.3、jack修改代碼提交合并

        jack對(duì)代碼做了如下修改

        main.cpp

        #include <stdio.h> #include <string.h>  int main() { 	char data[100] = "my branch name is B"; 	int length = strlen(data); 	 	for(int i = 0; i < length; i++) 	{ 		printf("%c", data[i]); 	} 	 	printf("branch BBBn"); 	 	return 0; }

        README.md

        this is BBB branch

        提交代碼并合并到主干

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git add .  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git commit -m "B分支代碼提交" [B bdcbe03] B分支代碼提交  2 files changed, 3 insertions(+), 3 deletions(-)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git push origin B Enumerating objects: 53, done. Counting objects: 100% (53/53), done. Delta compression using up to 12 threads Compressing objects: 100% (34/34), done. Writing objects: 100% (50/50), 4.66 KiB | 2.33 MiB/s, done. Total 50 (delta 16), reused 43 (delta 12), pack-reused 0 remote: Powered by GITEE.COM [GNK-6.2] remote: Create a pull request for 'B' on Gitee by visiting: remote:     https://gitee.com/lingpe/kaol/pull/new/lingpe:B...lingpe:master To https://gitee.com/lingpe/kaol.git  * [new branch]      B -> B  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git checkout master Switched to branch 'master' Your branch is up to date with 'origin/master'.  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $ git merge B Updating 40c0115..bdcbe03 Fast-forward  README.md | 2 +-  main.cpp  | 4 ++--  2 files changed, 3 insertions(+), 3 deletions(-)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $

        push時(shí)產(chǎn)生沖突

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $ git push origin master To https://gitee.com/lingpe/kaol.git  ! [rejected]        master -> master (fetch first) error: failed to push some refs to 'https://gitee.com/lingpe/kaol.git' hint: Updates were rejected because the remote contains work that you do hint: not have locally. This is usually caused by another repository pushing hint: to the same ref. You may want to first integrate the remote changes hint: (e.g., 'git pull ...') before pushing again. hint: See the 'Note about fast-forwards' in 'git push --help' for details.  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $

        2、解決沖突

        接下來(lái)就是如何解決沖突

        切換回B分支,然后拉取主干分支代碼

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git pull origin master remote: Enumerating objects: 7, done. remote: Counting objects: 100% (7/7), done. remote: Compressing objects: 100% (3/3), done. remote: Total 4 (delta 1), reused 0 (delta 0), pack-reused 0 Unpacking objects: 100% (4/4), 356 bytes | 178.00 KiB/s, done. From https://gitee.com/lingpe/kaol  * branch            master     -> FETCH_HEAD    40c0115..ccb2626  master     -> origin/master Auto-merging main.cpp CONFLICT (content): Merge conflict in main.cpp Auto-merging README.md CONFLICT (content): Merge conflict in README.md Automatic merge failed; fix conflicts and then commit the result.

        拉取失敗,可以看到提示信息,告訴我們哪個(gè)文件產(chǎn)生了沖突。

        直接打開(kāi)main.cpp文件,可以看到有以下特殊字符,提示我們哪一行代碼產(chǎn)生了沖突。

        #include <stdio.h> #include <string.h>  int main() { <<<<<<< HEAD         char data[100] = "my branch name is B"; =======         char data[100] = "my branch name is A"; >>>>>>> ccb26269f42245dfcbedfbf2218419c5ab7f2787         int length = strlen(data);          for(int i = 0; i < length; i++)         {                 printf("%c", data[i]);         }  <<<<<<< HEAD         printf("branch BBBn"); =======         printf("branch AAAn"); >>>>>>> ccb26269f42245dfcbedfbf2218419c5ab7f2787          return 0; }

        直接在文件中手動(dòng)解決沖突。刪除文件中的特殊字符,然后根據(jù)需求修改代碼。

        #include <stdio.h> #include <string.h>  int main() {         char data[100] = "my branch name is B and A";         int length = strlen(data);          for(int i = 0; i < length; i++)         {                 printf("%c", data[i]);         }          printf("branch BBBn");         printf("branch AAAn");         return 0; } ~

        同理,對(duì)README.md,手動(dòng)解決沖突。

        this is BBB and AAA branch

        解決完沖突后提交到B分支

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B|MERGING) $ git add .  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B|MERGING) $ git commit -m "解決沖突" [B f30e1ea] 解決沖突  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git push origin B Enumerating objects: 10, done. Counting objects: 100% (10/10), done. Delta compression using up to 12 threads Compressing objects: 100% (3/3), done. Writing objects: 100% (4/4), 405 bytes | 405.00 KiB/s, done. Total 4 (delta 1), reused 0 (delta 0), pack-reused 0 remote: Powered by GITEE.COM [GNK-6.2] To https://gitee.com/lingpe/kaol.git    bdcbe03..f30e1ea  B -> B  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $

        最后將B分支合并到主干,就不會(huì)產(chǎn)生沖突了

        lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (B) $ git checkout master Switched to branch 'master' Your branch and 'origin/master' have perged, and have 1 and 1 different commits each, respectively.   (use "git pull" to merge the remote branch into yours)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $ git merge B Updating bdcbe03..f30e1ea Fast-forward  README.md | 2 +-  main.cpp  | 4 ++--  2 files changed, 3 insertions(+), 3 deletions(-)  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $ git push origin master Total 0 (delta 0), reused 0 (delta 0), pack-reused 0 remote: Powered by GITEE.COM [GNK-6.2] To https://gitee.com/lingpe/kaol.git    ccb2626..f30e1ea  master -> master  lng@DESKTOP-9TD21KL MINGW64 ~/Desktop/jack/kaol (master) $

        至此,沖突成功解決

        可以看下主干分支的代碼

        main.cpp

        #include <stdio.h> #include <string.h>  int main() { 	char data[100] = "my branch name is B and A"; 	int length = strlen(data); 	 	for(int i = 0; i < length; i++) 	{ 		printf("%c", data[i]); 	} 	 	printf("branch BBBn"); 	printf("branch AAAn"); 	return 0; }

        README.md

        this is BBB and AAA branch

        OK

        推薦學(xué)習(xí):《Git教程》

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 精品国产污污免费网站| 国产69精品久久久久99| 97精品国产高清自在线看超| 亚洲精品无码永久在线观看你懂的 | 国产麻豆精品久久一二三 | 国内精品久久久久久久亚洲| 国产精品9999久久久久| 亚洲国产精品专区在线观看 | 无码精品久久久天天影视| 欧美激情精品久久久久久久九九九| 在线欧美v日韩v国产精品v| 99久久国产综合精品麻豆| 日韩欧精品无码视频无删节| 亚洲第一区精品观看| 久久久久国产精品麻豆AR影院| 99久re热视频这里只有精品6| 黑人精品videos亚洲人| 精品乱码久久久久久久| 人妻少妇精品无码专区二区| 亚洲欧洲久久久精品| 亚洲第一区精品观看| 日韩亚洲精品福利| 久久人人超碰精品CAOPOREN| 久久99国产精品99久久| 亚洲精品高清一二区久久| 精品国产一区二区三区2021| 人妻AV一区二区三区精品| 日韩精品电影一区亚洲| 国产欧美精品区一区二区三区| 久久99精品国产99久久6男男| 国产精品无码成人午夜电影 | 国产精品自在线拍国产第一页| 国产在线精品网址你懂的| 精品国产三级a∨在线| 日韩精品无码一区二区三区 | 欧美精品第一页| 国产精品美女一区二区视频| 香蕉久久夜色精品升级完成| 中文字幕无码精品三级在线电影| 呦交小u女国产精品视频| 亚洲日韩国产AV无码无码精品|