git版本回退(git reset、git revert、git stash)

文章目录

    • 回退的两种情况
      • 1.已 commit,未push到远程仓库。
        • 1.1 git reset --soft (撤销commit)
        • 1.2 git commit --amend(修改commit 提交的内容)
        • 1.3 git reset --mixed(撤销 commit 和 add 两个动作)
      • 2.已 commit,并且push到了远程仓库。
        • 2.1 git stash save "XXX"( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)
        • 2.2 git reset --hard 版本号(撤销并舍弃版本号之后的提交记录)
        • 2.3 git revert 版本号(撤销,但是保留了提交记录)


本文 git 相关命令:

git reset: 回退版本,可指定某一次提交的版本。git reset [--soft | --mixed | --hard] commitId

git revert: 撤销某个提交,做反向操作,生成新的commitId,原有提交记录保留。git revert commitId
git commit --amend: git commit –amend既可以对上次提交的内容进行修改,也可以修改提交说明
git status: 查看文件在工作区和暂存区的状态。

git log: 查看代码提交记录,找到需要回滚的目标版本号。

回退的两种情况

修改README.md前

回退分两种情况:

1.已 commit,未push到远程仓库。

git版本回退(git reset、git revert、git stash)_第1张图片
修改README.md后

git版本回退(git reset、git revert、git stash)_第2张图片

1.1 git reset --soft (撤销commit)

  • 修改了README.md,文档内容,并提交到了本地仓库
    git版本回退(git reset、git revert、git stash)_第3张图片
  • 此时回滚README.md,通过 git reset --soft HEAD^ 回退上一个commit
    git版本回退(git reset、git revert、git stash)_第4张图片
    注意: HEAD^的意思是上一个版本,也可以写成HEAD~1 ,如果你进行了2次commit,想都撤回,可以使用HEAD~2,这个命令仅仅是撤回commit操作,写的代码仍然保留

1.2 git commit --amend(修改commit 提交的内容)

  • 修改了README.md,文档内容,并提交到了本地仓库
    git版本回退(git reset、git revert、git stash)_第5张图片

  • 输入 git commit --amend,利用vim语法,点击i进入编辑模式,修改对应文本内容,点击Esc退出编辑模式,按键:wq强制退出

    在这里插入图片描述 git版本回退(git reset、git revert、git stash)_第6张图片
    在这里插入图片描述

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

  • 此时已经执行add和commit两个操作,git状态是这样的

    在这里插入图片描述

  • 输入git reset --mixed HEAD^ 撤销 commit 和 add 两个动作
    git版本回退(git reset、git revert、git stash)_第7张图片

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

2.1 git stash save “XXX”( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)

  • 输入git stash save "XXX"(能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录)
    git版本回退(git reset、git revert、git stash)_第8张图片

  • 输入git stash pop/apply ,将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
    注:pop将堆栈中最近保存的内容删除(栈是先进后出),aplly不会删除保存的内容
    git版本回退(git reset、git revert、git stash)_第9张图片
    git版本回退(git reset、git revert、git stash)_第10张图片
    可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。

  • git stash clear (清除堆栈中的所有 内容)

    本文主要讲版本回退,相关缓存操作,请自行查找

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

  • git log找到要回退到的版本号,当前第五次修改已缓存尚未提交,处于第四次提交的版本,此处要回退到第三次版本
    git版本回退(git reset、git revert、git stash)_第11张图片

  • 输入git reset --hard be125c629a893e28f62439cf71b1e9671c73a4bb 回退到第三版本
    在这里插入图片描述
    此时README.md文档内容为
    git版本回退(git reset、git revert、git stash)_第12张图片

  • git push -f(强制推送到远程,之前提交都会被覆盖,慎用)
    在这里插入图片描述
    注: 通过reset的方式,此时可用看到提交记录和文件都被撤销了,reset之后,后面的版本就找不到了使用需谨慎,不推荐使用。

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

  • git log找到要回退到的版本号,当前处于第四次提交的版本,此处要回退到第三版本
    git版本回退(git reset、git revert、git stash)_第13张图片

  • 输入git revert -n be125c629a893e28f62439cf71b1e9671c73a4bb^..HEAD 回退到第三版本

    在这里插入图片描述

  • 提交文件,并查看日志
    git版本回退(git reset、git revert、git stash)_第14张图片
    git版本回退(git reset、git revert、git stash)_第15张图片
    注: 这种方式不会把版本往前回退,而是生成一个新的版本。所以,你只需要让别人更新一下代码就可以了,你之前操作的提交记录也会被保留下来

你可能感兴趣的:(git,git,github)