git版本回退操作

git版本回退操作搞懂 git 回退命令 如果不慎提交 可通过 gitreset gitrevert 来撤销操作

git版本回退操作

本文 git 相关命令:

  • git reset:回退版本,可指定某一次提交的版本。git reset [–soft | –mixed | –hard] commitId。
  • git revert:撤销某个提交,做反向操作,生成新的commitId,原有提交记录保留。git revert commitId。
  • git status:查看文件在工作区和暂存区的状态。
  • git log:查看代码提交记录。
  • git cherry-pick:选择commitId 应用在当前分支。git cherry-pick commitId。

回退分两种情况:

  • 已 commit,未push到远程仓库。
  • 已 commit,并且push到了远程仓库。

已 commit,未push到远程仓库

git reset –soft(撤销commit)

touch 创建了一个a.text,并提交到了本地仓库。

git版本回退操作

此时回滚a.text,git log找到要回退到的版本号,此处版本号为前一个版本。(或者通过 git reset [HEAD] 回退版本)

git版本回退操作

执行命令:git reset –soft 7ee5305f1e1e0f66c7d69666ff7054fc6e

git版本回退操作

通过idea可看到commit 记录被撤销了。

git版本回退操作

git reset –mixed(撤销 commit 和 add 两个动作)

touch创建新文件 b.text, 并提交到本地仓库。

git版本回退操作

通过git log找到要回退到的版本号 7ee5305f1e1e0f66c7d69666ff7054fc6e

执行命令:git reset –mixed 7ee5305f1e1e0f66c7d69666ff7054fc6e

git版本回退操作

git版本回退操作

此时可以看到,git reset –mixed 撤销的文件 未加入到暂存区,所以是撤销 commit 和 add 两个动作。

已 commit,并且push到了远程仓库

git reset –hard(撤销并舍弃版本号之后的提交记录)

新建文件a.text,并push到远程。

git版本回退操作

执行命令:

  • git reset –hard 7ee5305f1e1e0f66c7d69666ff7054fc6e
  • git push -f(强制推送到远程,之前提交都会被覆盖,慎用)

git版本回退操作

此时可用看到提交记录和文件都被撤销了。使用需谨慎,不推荐使用。


当然,如果不小心用了git reset –hard操作回退了,那么可用git reflog命令查看命令历史,找到被删除的commit,再次操作。

git版本回退操作

git revert(撤销,但是保留了提交记录)

新建文件a.text,并push到远程。

通过 git revert 版本号,撤销当前提交记录。版本号为要撤销的版本号,此处为当前提交的版本号。

git版本回退操作

可以看到本地和远程仓库文件都被撤销了。但是git log中能看到提交和撤销记录。

推荐用这种方式回退远程的代码。比如我们在master分支提交错了文件需要回退,那么我们用这个方式回退后,再用git cherry-pick commitId 重放该提交。最后本地修改了再push到远程。

git版本回退操作

总结

回退分两种情况:

  1. 已 commit,未push到远程仓库。
    • git reset –mixed(撤销 commit 和 add 两个动作)。

    git reset –soft(撤销commit)。

  2. 已 commit,并且push到了远程仓库。
    • git revert(撤销,但是保留了提交记录)。

    git reset –hard(撤销并舍弃版本号之后的提交记录)。

git版本回退操作

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233408.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sqlformat数字格式化_java怎么输出数字

    sqlformat数字格式化_java怎么输出数字前言以前用到要对数字格式的地方,都是直接到网上搜一下。拿过来能用就行。因为平时用的不多。但是最近的项目对这个用的多了。网上拿来的不够用了。自己看了java源码把这方面恶补了。而且最近也好长时间没有写博客了。正好写一篇抛砖引玉吧。正文如果你对java源码比较了解。你会发现java对文字,数字的格式化,是有一个公共的父类的Format。NumberFormat和DecimalFormat都是它…

    2022年10月8日
    3
  • dos攻击防范措施_dos攻击和ddos攻击的区别

    dos攻击防范措施_dos攻击和ddos攻击的区别什么是Dos和DdoS呢?DoS是一种利用单台计算机的攻击方式。而DdoS(DistributedDenialofService,分布式拒绝服务)是一种基于DoS的特殊形式的拒绝服务攻击,是一种分布、协作的大规模攻击方式,主要瞄准比较大的站点,比如一些商业公司、搜索引擎和政府部门的站点。DdoS攻击是利用一批受控制的机器向一台机器发起攻击,这样来势迅猛的攻击令人难以防备,因此具有较大的破坏性。如果说以前网络管理员对抗Dos可以采取过滤IP地址方法的话,那么面对当前DdoS众多伪造出来的地址则显得没有办

    2022年10月1日
    3
  • 构造函数与析构函数详解[通俗易懂]

    构造函数与析构函数详解

    2022年2月7日
    46
  • 数据结构 图的邻接表

    数据结构 图的邻接表呃,下面该写邻接表了…….邻接表的出现是因为图若是稀疏图,用邻接矩阵会造成空间的浪费,毕竟你要开辟一个一维数组和一个二维数组嘛,而且还是大开小用的那种。邻接表为了避免内存的浪费引入了链式存储,它的处理办法是:1.用一个一维数组存储顶点,当然你也可以用单链表存储,2.用单链表存储顶点的邻接点,可以将顶点改为结构体数组,结构体中存放邻接点的指针,邻接点也创建一个结构体,定义指针…

    2022年6月28日
    22
  • WinForm界面优化工具

    WinForm界面优化工具引用等待尝试http://space.itpub.net/12639172/viewspace-678321

    2022年5月27日
    42
  • C#数组–(一维数组,二维数组的声明,使用及遍历)

    C#数组–(一维数组,二维数组的声明,使用及遍历)数组:是具有相同数据类型的一组数据的集合。数组的每一个的变量称为数组的元素,数组能够容纳元素的数称为数组的长度。一维数组:以线性方式存储固定数目的数组元素,它只需要1个索引值即可标识任意1个数组元素

    2022年7月2日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号