Git冲突:commit your changes or stash them before you can merge

Git冲突:commit your changes or stash them before you can merge

在使用 git pull命令下拉远程分支代码时,报了 commit your changes or stash them before you can merge 这个错误。

1、报错原因

请先看报错截图:

image-20210319142824053

从报错提示可以知道,远程分支与本地分支修改了同一个文件,导致了 Git 冲突。在这个截图中,由于我本地修改了 application.properties文件,而远程分支上也同样修改了这个文件,导致无法 git pull

2、解决方法

思路:这个时候可以先把本地工作区的修改暂存到栈中,然后下拉远程分支代码,接着取出栈中的修改进行合并。

  • git stash命令把当前工作区和暂存区的改动保存到栈中,接着恢复本地分支为改动前的分支,通过 git status可以查看分支状态。
  • 此时执行git pull便能够下拉远程分支代码。
  • 执行 git stash pop取回保存在栈中的本地分支的修改,最后解决冲突。

因此,需要执行的命令行如下:

# 保存当前工作区和暂存区的改动到栈中
git stash
# 获得远程分支代码
git pull
# 恢复栈中最新的工作区和暂存区的改动到工作区,并删除栈中信息
git stash pop

3、stash其他常用命令

# 获取堆栈列表
git stash list

# 恢复最新的进度到工作区和暂存区。(尝试将原来暂存区的改动还恢复到暂存区)
git stash pop --index

# 恢复指定的进度到工作区,删除栈中信息
git stash pop stash@{1}

# 恢复指定的进度到工作区,不删除栈中信息
git stash apply stash@{1}

# 清空堆栈列表
git stash clear

# 删除指定的栈中信息
git stash drop stash@{1}
posted @ 2021-03-29 09:25  MyDistance  阅读(480)  评论(0编辑  收藏  举报