【Git】-- 处理 Git 提交到错误分支的问题

如果你不小心把本应提交到 test 分支的代码提交到了 master 分支(但尚未 push),可以按照以下步骤解决:

方法一(推荐):使用 git resetgit stash

  1. 首先,确保你在 master 分支:git checkout master

  2. 撤销最后一次提交但保留更改:git reset HEAD~1

    或者如果你想保留提交信息:git reset --soft HEAD~1

  3. 暂存你的更改:git stash

  4. 切换到 test 分支:git checkout test

  5. 应用暂存的更改:git stash pop

  6. 重新提交更改:

    复制代码
    $ git add .
    $ git commit -m "你的提交信息"

方法二:使用 git cherry-pick

如果你已经做了多个提交,或者想保留原来的提交信息:

  1. 首先切换到 test 分支:git checkout test

  2. master 分支挑选提交:git cherry-pick <commit-hash>

    其中 <commit-hash> 是你在 master 上的错误提交的哈希值。

  3. 回到 master 分支并删除错误的提交:

    复制代码
    $ git checkout master
    $ git reset --hard HEAD~1

方法三:创建新分支并重置

如果你愿意,也可以:

  1. 从当前 master 创建新分支:git branch test

  2. 重置 master 到之前的状态:

    复制代码
    git checkout master
    git reset --hard origin/master
  3. 切换到 test 分支继续工作:git checkout test

推荐:方法一通常是最简单直接的解决方案。

相关推荐
云计算练习生13 小时前
linux shell编程实战 10 Git工具详解与运维场景实战
linux·运维·git
MUTA️1 天前
git传输超过100MB的文件
git
ALex_zry1 天前
Git大型仓库推送失败问题完整解决方案
大数据·git·elasticsearch
二进制coder1 天前
Git Fork 开发全流程教程
大数据·git·elasticsearch
程序员馨馨1 天前
不扰远程仓库,本地双版本:master 留 A 稿,分支藏 B 稿
git
无限进步_1 天前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
用户47861297206921 天前
Git:如何排查非线性历史中被隐秘覆盖的修改(完整实战笔记)
git
weixin_377634841 天前
【Git使用】PyCharm中的Git使用
ide·git·pycharm
爱吃泡芙的小白白1 天前
vscode、anaconda、git、python配置安装(自用)
ide·git·vscode·python·anaconda·学习记录
ALex_zry2 天前
Git大型仓库推送失败问题解决方案:大文件传输优化指南
git