git的工作流程-- 3个区域

  工作区:我们可以看到的文件内容  在操作 git add 之前的!!

  缓存区:是不可见的   已经git add操作,还没git commit -m “”操作

  历史区:将缓存区中,临时存储的文件,生成历史版本   已经git commit -m

  基本工作流程:

    工作区编辑 ---> 存储缓存区 ---> 历史版本 ---> 上传github

         github ---> 下载工作区进行编辑

代码回滚

  1、在工作区的代码

    git checkout --文件名  丢弃某个文件

    git checkout --.      丢弃全部

    对之前保存在缓存区里的代码不会有任何影响。对commit提交到本地分支的代码就更没影响了。如果你之前压根都没有缓存或commit,那就是回到你上次pull下来的样子了。

  2、git add到了缓存区,没有git commit -m

    git reset HEAD .

    git reset HEAD 文件夹名

    仅改变缓存区,并不改变工作区。

  3、git commit -m 到本地分支,没有git push 远端

    git log     查看提交的版本信息  版本号

    git reset --hard 版本号  回到想要的版本

    git reset --hard HEAD^  回到最新一次提交

    git reset HEAD^     此时代码保留,回到git add操作之前(表示需要重新add)

  4、git push 把修改提交到了远端仓库

    ①通过 git reset

      git log  查看版本信息  版本号

      git reset --hard 版本号

      git push origin HEAD --force      强制提交一次  之前错误的提交会删除

    ②git revert  用新的 commit 回滚之前的 commit

      git log  查看版本信息  版本号

      git revert 版本号    撤销指定的版本,撤销也会作为一次提交进行保存

    git revert 和git reset 区别

      git revert是用一次 新的commit 来回滚之前的commit,此次提交之前的commit都会被保留;

      git reset是 回到某次提交,提交及之前的commit都会被保留,但是此commit id之后的修改都会被删除

撤销

  将“本地仓库”的代码还原操作叫做“撤销”!

  1、文件修改,没执行git add

    git checkout 文件名

    git checkout .

  2、同时对多个文件 git add,但想提交部分

    $ git add *

    $ git status

    $ git reset HEAD 文件名    取消缓存

  3、执行了 git add ,想撤回修改

    git reset HEAD 文件名     取消缓存

    git checkout 文件名      撤回修改

  4、行了多次git commit操作,想撤销到其中某次Commit

   git reset [--hard|soft|mixed|merge|keep] [commit|HEAD]

  

    

 
 

git的回滚与撤销【reset and revert】的更多相关文章

  1. Git如何回滚代码?

    摘要: 多年以后,你面对一个需要回滚的Git仓库,准会想起这篇博客. 某一天,用户跟我反馈,他不能分配任务了.我去看了一下Fundebug捕获的报错信息: 可知,出错原因是前端发送的请求参数有问题.这 ...

  2. git如何回滚当前修改的内容?

    git如何回滚当前修改的内容? 1.打开git gui,在工具栏上点击 commit ,选择 Revert Changes,  这里可以回滚单个文件: 2.一键回滚所有修改: 打开git gui,在工 ...

  3. Git 中的回退操作:reset 和 revert

    Git 中回退有 reset 和 revert,这两个的区别就是是否保留更改记录 假设当前的提交情况是:A <- B <- C <- D <- HEAD,如下图: 当前是 D, ...

  4. git代码回滚:Reset、Checkout、Revert的选择

    代码回滚:Reset.Checkout.Revert的选择 Zhongyi Tong edited this page on Dec 8, 2015 · 5 revisions Pages 19 Ho ...

  5. Git使用小技巧之回滚和撤销

    想要获取更多文章可以访问我的博客 - 代码无止境. 日常的开发,我们难免会创建错误的git提交记录,整个时候git给我们提供了两个命令来解决这个问题.一个命令是git reset,另一个是git re ...

  6. git push之后回滚(撤销)代码

    问题描述:首先,先说明一下,为什么会引发这次的话题,是这样的,我做完功能Agit push之后,2个月后需求部门要求不要功能A了,然后需要在没有功能A的基础上开发,怎么办?赶紧回滚代码呀. 然后我用g ...

  7. git 代码回滚与爬坑 -- reset and revert

    本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/git_code_roll_back_revert_and_res ...

  8. git代码回滚的两种选择

    回滚到指定commit,且保持该commit之前和之后的提交记录 使用git revert命令. git revert HEAD // 回滚到前一次 commit git revert HEAD^ / ...

  9. Git的回滚

    Git常用命令: git add .   #进行提交 git commit -m v2 #v2版本 cat index.html #查看文件内容已经变化 git log #获取到提交信息 git re ...

随机推荐

  1. Spring Cloud实战 | 第十一篇:Spring Cloud Gateway 网关实现对RESTful接口权限控制和按钮权限控制

    一. 前言 hi,大家好,这应该是农历年前的关于开源项目 的最后一篇文章了. 有来商城 是基于 Spring Cloud OAuth2 + Spring Cloud Gateway + JWT实现的统 ...

  2. MySQL——时间、字符串、时间戳相互转换

    一.时间转字符串 select data_format(now(),'%Y-%m-%d %H:%i:%s'); 二.时间转时间戳 select unix_timestamp(now()); 三.字符串 ...

  3. ACM-ICPC 2018 徐州赛区网络预赛 B BE, GE or NE 【模拟+博弈】

    题目:戳这里 题意:A和B博弈,三种操作分别是x:加a,y:减b,z:取相反数.当x或y或z为0,说明该操作不可取,数据保证至少有一个操作可取,给定一个区间(l,k)和原始数字m,如果A和B在n次操作 ...

  4. OAuth2授权流程

  5. 银河麒麟V10安装ASP.NET Core并配置Supervisor让网站开机自动运行

    银河麒麟高级服务器操作系统V10是针对企业级关键业务,适应虚拟化.云计算.大数据.工业互联网时代对主机系统可靠性.安全性.性能.扩展性和实时性的需求,依据CMMI 5级标准研制的提供内生安全.云原生支 ...

  6. GitHub rename the default branch from master to main

    GitHub rename the default branch from master to main master => main Repository default branch Cho ...

  7. webpack defineConstants

    webpack defineConstants PAGES 全局常量/全局变量 https://webpack.js.org/plugins/define-plugin/ taro https://n ...

  8. taro scroll tabs 滚动标签 切换

    taro scroll tabs 滚动标签 切换 https://www.cnblogs.com/lml-lml/p/10954069.html https://developers.weixin.q ...

  9. qt 注册热键

    原文 将所需的库添加到您的qmake项目(.PRO文件) LIBS += \ -lUser32 2.在代码中包含所需的头文件. #include <windows.h> 在程序开始时注册热 ...

  10. NGK 路演美国站,SPC空投与NGK项目安全

    最近,NGK全球巡回路演在美国最大城市纽约市落下帷幕,本次路演有幸邀请了NGK方面代表迈尔逊,纽约当地区块链大咖维克多以及美国当地社群意见代表乔治等人. 路演一开始,美国当地路演师Viko首先致辞,V ...