• 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}
    
    自我控制是最强者的本能-萧伯纳
  • 相关阅读:
    (转)EDM邮件制作规范完整版
    (转)Gmail,你必须了解的12个邮件编码问题
    说说CakePHP的关联模型之一 基本关联
    HTML5 离线应用程序
    CakePHP模型中使用join的多种写法
    判断浏览器
    Javascript闭包例子
    安装wamp后,其显示目录的图标显示不出来
    underscore.js 分析 第二天
    HTML5心得
  • 原文地址:https://www.cnblogs.com/CF1314/p/14591004.html
Copyright © 2020-2023  润新知