git pull时的冲突解决方式; git stash; git fetch

git fetch指令:

 

 https://www.yiibai.com/git/git_pull.html

 


 

发现远端有更新,git pull时,如果你本地分支修改了东西,导致git pull有冲突,失败。这时可以有两种方式解决问题。

关于git pull的实验:

本地有分支branch1,对应远端的分支branch1, 两端状态相同。

当前工作区处于branch1,我更改一个文件file并保存,然后执行git pull,得到提示”Already up to date“; 然后,我执行git add file,然后,执行git pull,得到相同的提示;

然后,执行git commit -m“xx” 将我的修改进行commit,然后执行git pull,也得到同样的提示!

--- 也就是说, git pull完全没有起作用! ---原因: 远端分支没有人没有更新过,git pull不起作用

 

本地有分支branch1,对应远端的分支branch1, 两端状态相同。然后,远端被人更新::

1)你当前工作区处于branch1,并修改file文件保存,不执行add, commit。

然后执行git pull,会提示冲突:
error: Your local changes to the following files would be overwritten by merge:
        file1.txt
Please commit your changes or stash them before you merge.
Aborting

git pull命令虽然相当于git fetch 加 git merge,但是此时远端的最新代码并没有被fetch到你的本地仓库,即你的本地仓库和工作区都没有被更新。

 

2)你当前工作区处于branch1,并修改file文件保存,执行git add file,不执行commit。

然后执行git pull,会提示同上的冲突。

 

3)你当前工作区处于branch1,并修改file文件保存,执行git add file,执行git commit -m"comments"。然后执行git pull,提示:

CONFLICT (content): Merge conflict in file1.txt
Automatic merge failed; fix conflicts and then commit the result.
这时,你的命令行处于merging状态,同时,你的本地文件别git 修改,帮你标记出冲突的地方了。这时执行git status会提示:(即,修改了工作区的文件,并add ,commit之后,执行git pull时,才会执行merge动作。)

即,你可以

  a)   执行git  merge --abort取消这次git  pull操作,执行后你本地文件不变,本地仓库的这个分支也不变;;

  b)  或者,手动修改git 标记的冲突内容文件并保存,执行git add file以mark resolution, 然后,执行git status 发现:

 

     然后,按照提示执行git commit 将你的merge后的文件commit到本地仓库就完成这次merge 啦。 这样有一个缺点,即合并冲突解决后,你再执行git status会发现你本地比远端多两个commit,这时因为你执行git pull之前已经做过git commit,这里为了解决冲突又做了一次,导致了你的本地内容虽然与远端一致但是commit记录不同步,,因此,还是不要直接在本地分支(该分支对应远端)上修改内容,而是先新建一个本地分支并在其上进行功能开发,开发完毕后进行       merge.  (commit记录不同步好像影响不大,下文中的git stash就是先解决了冲突再commit)

  c)  或者,执行git merge tool(please ref to: )


 

 git pull提示冲突的情况对应上文中的1) 和 2)情况,即你没有git commit你本地的修改。可以又两种方法搞定:

1)放弃本地修改

     让 本地仓库 代码覆盖  本地工作区 修改,然后更新远程仓库代码; 

     本地仓库 代码完全覆盖本地  工作区间,具体指令如下:

     git checkout head . (注意: 别遗漏 "head" 后的 " ." )(执行后,你本地的缓存区域的内容也被抛弃了,如果你执行过git add的话)

    有人画了下图:

 

     然后更新远程仓库的代码就不会出现冲突了: git pull

 

2)用git stash

将本地修改的代码放在缓存区, 然后从远程仓库拉取最新代码,拉取成功后再从缓存区将修改的代码取出, 这样最新代码跟本地修改的代码就会混杂在一起, 手工解决冲突后, 提交解决冲突后的代码。

 执行git pull提示冲突之后,执行

git stash,

然后,git pull就可以没有冲突了;

然后,git stash pop,将刚才缓存的内容merger到当前新拉下来的, 手动解决冲突,然后git add, git commit, git push.

 

posted @ 2019-08-03 16:50  JadeCicada  阅读(1080)  评论(0编辑  收藏  举报