【IDEA checkout分支冲突,点rollback后,之前add但未commit的代码找回】

博主在使用IntelliJ IDEA时,add代码但未commit,checkout到master分支拉取代码起冲突,rollback后代码丢失。解决办法是利用IDEA静默搁置功能,点击Unshelve Silently恢复代码。还给出避免此问题的方法,即通过特定操作将master分支代码合并到当前分支。

IDEA 找回add但未commit的代码 shelve静默搁置

场景还原:

前几天写了一些代码add了,但还没有commit。
此时想checkout到master分支拉取一下最新的代码,结果起冲突了。
但是又不想解决冲突,打算切回我自己的分支,然后就点了idea的rollback,结果之前的代码都没了。

解决:

  • 发现idea有静默搁置的功能,这里面保存了之前的代码。
    在这里插入图片描述
  • 点击 Unshelve Silently 即可
    在这里插入图片描述

更好的方式(避免出现这个问题):

  1. 点击要合并新代码的分支master,点击箭头update在这里插入图片描述
  2. 再次点击到master上,点击右键,选择将master和并到当前分支上。在这里插入图片描述
在使用 IntelliJ IDEA 时,切换到本地新分支并保留当前提交的代码变更可以通过以下几种方式实现: ### 创建并切换到新分支并保留更改 1. **通过 Git 工具创建新分支:** -IDEA 的右下角击当前分支名称(如 `develop`)。 - 击 "Git: [branch_name]" 弹出窗口中的 **+** 号来创建一个新分支- 输入新分支的名称并击 “Create” 按钮。 -分支创建完成后会自动切换至该分支,同时本地提交的更改会被保留在工作区中[^4]。 2. **命令行方式:** 如果你更喜欢使用命令行,可以在项目根目录打开终端并执行以下命令: ```bash git checkout -b new_branch_name ``` 此命令会在创建新分支的同时切换到该分支,并且保留所有提交的更改。这种方式适用于需要快速创建和切换分支的情况[^2]。 3. **使用 Smart Checkout 功能:** - 当你在 IDEA 中尝试切换分支时,如果当前分支提交的更改,IDEA 会弹出提示框询问你是选择 **Smart Checkout** 还是 **Force Checkout**。 - **Smart Checkout** 会将提交的更改带入新的分支中,而不会丢失这些更改。 - 选择 **Smart Checkout** 后,IDEA 会自动保存当前的工作状态,并切换到目标分支,确保你的更改仍然存在[^2]。 4. **手动保存更改并应用到新分支:** - 如果你担心操作失误或者想更加灵活地管理更改,可以先使用 `git stash` 命令将提交的更改暂存起来: ```bash git stash save "message" ``` - 然后创建并切换到新分支: ```bash git checkout -b new_branch_name ``` - 最后将之前暂存的更改应用到新分支上: ```bash git stash apply ``` 这种方法适合处理较为复杂的开发场景,尤其是当你需要多次切换分支时。 ### 注意事项 - **避免使用 Force Checkout:** 如果你选择了 **Force Checkout**,那么当前分支上的所有提交更改将会被丢弃,这可能导致数据丢失。如果不慎使用了此选项,可以通过 **Local History** 功能找回丢失的代码- **检查代码完整性:** 切换分支后,请务必检查代码是否完整无误,特别是当多个文件被修改时,建议进行逐个确认。 ###
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值