站長(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)
        主站蜘蛛池模板: 宅男在线国产精品无码| 久久精品中文字幕无码绿巨人| 亚洲精品无码久久久久AV麻豆| 欧美巨大黑人精品videos| 中日精品无码一本二本三本| 国产成人精品久久亚洲| 国产香蕉精品视频在| 精品国产福利一区二区| 欧美精品亚洲精品日韩精品| 国产精品va久久久久久久| 国产精品自拍一区| 99久久久国产精品免费无卡顿| 性欧洲精品videos| 亚洲国产精品毛片av不卡在线| 国产小呦泬泬99精品| 亚洲精品欧美日韩| 欧美精品一区二区精品久久| 国产成人精品日本亚洲11| 国产精品丝袜黑色高跟鞋| 久久精品国产亚洲av麻豆色欲| 亚洲日韩国产AV无码无码精品| 国产精品亚洲高清一区二区| 99久久国产主播综合精品| 久久久精品一区二区三区| 国产成人精品天堂| 国产成人久久精品区一区二区| 久久精品国产亚洲av影院| 久久久久成人精品无码中文字幕| 亚洲精品美女久久久久99| 亚洲国产精品乱码一区二区| 亚洲AV无码成人精品区蜜桃| 亚洲国产精品久久久天堂| 日韩人妻精品一区二区三区视频 | 国产精品麻豆VA在线播放| 亚洲精品国产成人99久久| 亚洲精品欧美综合| 国产成人99久久亚洲综合精品| 成人精品一区二区三区电影黑人| 国产精品久久久久久久午夜片| 国产在线精品一区二区三区不卡| 精品国产香蕉伊思人在线在线亚洲一区二区|