Git 切换分支不想提交代码该如何处理

Git 切换分支不想提交代码该如何处理

Git 切换分支不想提交代码该如何处理 - 星云惊蛰 - 博客园

在B分支工作时,突然来了个紧急需求,需要切到C分支作业。但并不想提交B的代码该如何处理呢?
可以把代码暂时提到缓存区,切换到C分支进行编写,完成需求提交代码后,切回B分支读取缓存即可。
附缓存指令:

git stash // 缓存
git stash save 'message' // 推荐使用这个 可以根据存取的message分辨缓存
git stash list // 缓存列表
git stash pop // 读取缓存的最后一个并从list中删除该缓存
git stash apply stash@{n} // 读取指定缓存 不会自动删除 stash@{n} 为list中 你所要读取的缓存的序号
git stash drop stash@{n} // 手动删除指定缓存
// 查看缓存的时间
git stash list --date=relative
git stash list --date=short
git stash list --date=local

git stash list stash@{n}为序号 on 后面是分支名引号里面是save存储的message

假如现在的Bug你还没有解决,而上边又给你派了一个新的Bug,而这个Bug相比较现在正在苦思冥想的Bug比较容易解决。

你想先解决新的Bug,可是之前的Bug还没有解决完而不能提交。怎么办?

解决方法:在其他分支上另开炉灶解决。

首先你需要将此刻正在解决Bug的当前分支“储藏”起来。例假如此时正在你在当前分支dev上已进行了Bug修改但还未提交。

此时你想去解决刚派下来的另一个Bug。而你需要在master分支上去修复这个Bug,第一步就需要先切换到master 分支。当你执行 $ git checkout master 命令的时候,将提示出错:

error: Your local changes to the following files would be overwritten by checkout:
        readme.txt
Please commit your changes or stash them before you switch branches.

(请在切换分支之前提交您的更改或隐藏它们)

因为当前的分支dev 最初也是从master 分支上衍生出来的。而此时你要再从该分支上切换到其主分支。那么你需要先把该dev分支上的改动提交后才能切换,但是该dev分支上还没有完成全部的修改,你不想提交。那么此时你就要选择 stash 它们(你在当前分支上改动的却没有提交commit的内容)。

所以第二步,在当前分支上执行  $ git stash 命令。将当前分支存起来,id为 8528ea2 s

这时候再执行 $ git status 命令,显示没有东西需要提交,这个时候你就可以切换到master分支上了。

接着就可以在主分支master上创建并切换到新的分支去修复另一个Bug了。

那修改完那个Bug也提交后,就该回到dev 分支上去继续修改那个未完成的Bug。

执行  $ git checkout dev 切换到 dev 分支,这个时候执行 git status 命令仍旧显示没有东西需要提交。毕竟我们前边已经成功将dev上未提交的改动给“隐藏“了,这时,用  $ git stash list  命令去查看我们“存储”的列表。

会发现id 为  8528ea2 s 的储藏项目在列表中,我们需要将其恢复,有两个办法:

一、用 $ git stash apply 命令恢复,但是恢复后,stash内容并不删除,这时候再执行  $ git stash list 命令,id 为  8528ea2 s 的储藏项目还会在列表中,你需要用 $ git stash drop 来删除;


注意: 如果有一个分支上多个 stash,如果需要恢复指定的 stash ,可以在命令尾部加id,如  $ git stash apply stash@{0},同样删除指定 stash 项目则执行如 $ git stash drop stash@{1}  。


二、用  $ git stash pop  命令,恢复的同时把 stash 存储列表的内容也删了。这时候再执行  $ git stash list 命令,id 为  8528ea2 s 的储藏项目不会在列表中。

此时再查看 $ cat <filename>  会发现之前的改动还存在,且执行 git status 就会继续显示该分支上有改动未提交。

Git是目前广泛使用的版本控制系统,它允许用户在不同的分支上进行开发,从而可以并行处理不同的任务。在使用Git进行分支切换和代码回滚时,如果不正确操作,可能会导致代码丢失。以下是Git切换分支和回滚代码时的几个注意事项: 1. 切换分支前请确保当前分支的更改已经提交,或者已经用stash暂存起来。如果直接从未提交的分支切换到另一个分支,Git会提示你必须先提交更改或者暂存更改。这样做是为了防止你的更改丢失。 2. 如果在切换分支之前进行了提交,但在切换分支后想要回滚到之前的某个提交,你可以使用`git reset`命令。例如,`git reset --hard HEAD~1`将会把当前分支的HEAD指针回退到上一个提交,并且丢弃之后的所有更改。这可能会导致工作区中的代码与仓库中的代码不同步,所以操作前要确保这是你真正想要的结果。 3. 如果你已经提交了更改并且推送到远程仓库,那么在切换分支并回滚本地代码之后,当你再次推送时,远程分支可能会有冲突。因为远程分支包含了本地回滚之前提交的更改。在这种情况下,需要使用`git push -f`来强制推送你的本地分支到远程仓库,以覆盖远程分支的历史。 4. 如果你在切换分支前使用了`git stash`来暂存了更改,并在之后的某个时刻想要恢复这些更改,你可以使用`git stash pop`命令。这个命令会将暂存的更改重新应用到当前分支上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值