IDEA小技巧-Git的回滚&&强推&&代码找回(超具体) ...

打印 上一主题 下一主题

主题 507|帖子 507|积分 1521

PS:我们这里对 Test1 文件的 add ,commit 以及 push 展开讨论
在本地 add 到暂存区但未 commit 的代码回滚方式

对于新增以及修改的文件

直接鼠标右键文件举行回滚

已经 commit 但未 push 的代码回滚方式

undo commit

回退最后一次提交,且只能回退最后一次提交,commit的内容都会被生存,被修改或新增的代码都会被生存
使用 undo commit 前


使用 undo commit 后



留意:这里是选择变动列表,我们一般使用默认的就行

可以看见 Test1 变绿,回滚了提交,即回到了 add 状态
drop commit

直接删除提交,并回退代码,被修改或新增的代码都会被复原
使用 drop commit 前


使用 drop commit 后



revert commit

使用后新增一次 revert 记录,并回退代码
使用 revert commit 前


使用 revert commit 后



留意

回滚一般是回滚最近一次提交,假如你想要回滚中间的提交,大概必要蒙受冲突合并等一系列题目
reset

对于前面的 revert commit 以及 drop commit 都是单点的回滚,假如想要一次性的从最近的一次提交一步一步地到指定的提交,这时候就必要用到 reset 了
soft

在选定提交之后所做的所有更改都在暂存区中
commit的内容都会生存,其新增文件 + 文件变动都在暂存区
mixed

在选定提交之后所做的更改将被生存,但不会暂存以举行提交。
commit的内容都会生存,新增文件在工作区,文件变动在暂存区
hard

在选定提交之后所做的所有更改都将被抛弃(暂存和已提交)
commit的内容+暂存区的内容全部被丢弃
keep

在选定提交之后的已commit内容将被丢弃,但未commit的部分将生存
commit部分内容被丢弃,未commit部分生存
示例




选择 hard ,结果是
在选定提交之后所做的所有更改都将被抛弃(暂存和已提交)
commit 的内容+暂存区的内容全部被丢弃
已经 commit 并且 push 的代码回滚方式

发生题目场景


  • 想要重新生成 commit message
  • 代码没写好给 push 到远程堆栈了
以下是我们的预期示例图

由于 git 对代码的掩护机制,导致我们无法直接将原F删掉,更换成我们的新的F’,所以我们必要接纳特别的手段到达目的,即 强推
首先我们将本地的代码推送到远程堆栈

假如这个时候我们想要修改 commit message,那这个时候就必要以下操作
然后 reset 我们远程的分支



这时候假如我们再 commit test ,然后 push 的话会报错

这是处于 git 的掩护机制,想要我们处理冲突,我们显然是不想处理的,而是直接更换掉远程堆栈的 test 提交
那么这个时候就必要使用 强推 这个操作了

但是我们这个时候 force push 是灰色的,怎么回事呢?

嘿嘿,不急
打开设置,删除受掩护分支。

这时候就可以点击 强推 了

这时候远程分支就和本地分支同等了

这时你就可以重新上传分支到远程堆栈了
另外留意

强推有风险,假如你的项目是多人开辟的话,很有大概会覆盖别人写的代码,造成不可挽回的后果
代码找回

假如我们不小心误回滚了我们的代码如何找回呢
这时我们可以随地找出空缺处右键


这个时候我们即可通过 revert 举行代码找回
本篇文章参考于:https://www.bilibili.com/video/BV1Wa411a7Ek/?spm_id_from=333.880.my_history.page.click

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

雁过留声

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表