必要的概念

  • 当前编辑界面:工作区(workspace)
  • “git add”命令:将改动加入到缓存区(Index)
  • ”git commit”命令:提交代码到本地库(Local Repository)
  • ”git push”命令:提交代码到远程库(Remote Repository)

未使用“git add”命令缓存代码时

git checkout

git checkout -- <filepathname>  # 丢弃工作区某个文件的修改
git checkout . # 丢弃工作区所有文件的修改

注意:此命令不会删除掉新建的文件,需要手动删除。

已使用“git add”命令缓存代码

git reset

git reset HEAD <filepathname>  # 撤销暂存区某个文件的修改,重新放回工作区
git reset HEAD . # 撤销暂存区所有文件的修改,重新放回工作区

注意:相当于撤销“git add”命令,但只是将本地的修改从暂存区回退到工作区。

已使用“git commit”命令提交代码

git reset

git reset --hard HEAD^ <filepathname>   // 回退某个文件到上一次commit的状态
git reset --hard HEAD^ // 回退所有文件到上一次commit的状态
git reset --hard <commit id> // 回退所有文件到某个commit

git commit --amend

重做上一次commit,并包括指定文件的新变化。

合并缓存区的修改和最近的一次commit,并尝试重新commit。可以理解为,用一个全新的commit整个替换了最近一次commit。

如果缓存区没有内容, 可以用来编辑上一次的commit描述。

不要对一个公共的commit使用amend。如果amend了一个被其他开发者使用的commit, 可能会严重影响其他开发者。

git rebase

重新定义分支的起点,也就是将当前分支从一个commit移动到另一个commit作为起点。

分支上的老commit将被删除,保持了项目历史的干净。建议不要在一个公共的分支中使用rebase。

git rebase <base>   # 将<base>做为当前分支的新起点, <base>可以是任何一种commit引用(如ID,branch name,tag,HEAD~N等)。
git rebase -i <base> # 交互式地将<base>做为当前分支的新起点,过程中可以对要rebase的commit做一定的修改。

"git reset"命令

用来撤销本地的修改。建议不要reset一个公共的项目历史。

主要参数:

  • --soft 回退后a分支修改的代码被保留并标记为add的状态(git status 是绿色的状态)
  • --mixed 重置索引,但不重置工作树,更改后的文件标记为未提交(add)的状态。默认操作。
  • --hard 重置索引和工作树。
git reset  # 回退版本库到上一个commit的状态, 工作区不变。
git reset <commit> # 回退版本库到指定的<commit>, 工作区不变。 git reset --hard # 回退版本库和工作区到上一次commit的状态。 --hard表明覆盖所有的修改, 而且是不可逆的, 因此使用之前要谨慎。
git reset --hard <commit> # 回退版本库和工作区到指定的<commit>。 git reset --hard origin/master # 将版本库和工作区回退到和远程的一样。

回退到上个版本:git reset --hard HEAD^ <filepathname> git reset --hard HEAD^ git reset --hard HEAD~

回退到上上个版本:git reset --hard HEAD^^ git reset --hard HEAD~1

以此类推。

Git - 回滚与撤销的更多相关文章

  1. git merge 撤销与git 回滚

    git merge提交后恢复 http://blog.psjay.com/posts/git-revert-merge-commit/ git回滚 https://www.jianshu.com/p/ ...

  2. git回滚

    Git回滚的常用手法 07net01.com 发布于 4小时前 评论 传统VCS的回滚操作 对于版本控制系统VCS来说,回滚这个操作应该是个很普通也是很重要的需求. 如果你是传统VCS,比如SVN或者 ...

  3. Git回滚代码暴力法

    Git回滚有多种方式,这里使用的是[强制提交到远程分支] 效果为:如回滚前的提交记录是 1.2.3.4,使用这种方法回滚到2,那么提交记录就变成了1.2. 操作方法: 需要在本地的Git仓库,右键选择 ...

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

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

  5. git的回滚与撤销【reset and revert】

    git的工作流程-- 3个区域 工作区:我们可以看到的文件内容 在操作 git add 之前的!! 缓存区:是不可见的  已经git add操作,还没git commit -m "" ...

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

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

  7. git 回滚方式

    git push 命用于从将本地的分支版本上传到远程并合并. 命令格式如下: git push <远程主机名> <本地分支名>:<远程分支名> 如果本地分支名与远程 ...

  8. git回滚错误提交

    git log //找到你要回滚的那次提交 比如:43596f6b1f57157e627c25ae7a843f60157ac52d git reset --hard HEAD~43596f6b1f57 ...

  9. git 回滚远程服务端master的代码

    1.先备份版本 git checkout master git pull git branch master_backup //备份一下这个分支当前的情况 git push origin master ...

随机推荐

  1. Enjoy Markdown!

    有一个神奇的语言,比HTML简单,它巧妙地将内容与格式结合在一起,它就是Markdown! 下面是一个用C语言写的四则运算小测试~ #include <stdio.h> #include ...

  2. shell for if

    #!/bin/bash ..} do ];then j="${i}" else j="${i}" fi echo $j >> venn.log ec ...

  3. hdu-1800(字符串hash)

    题目链接:传送门 思路: 就是找最多多少个扫帚,每个扫帚上有连续递增的序列,就是找一个最多重复数字的重复次数. 由于是30位,每次用char*类型,然后用hash映射一下,排序找最多就行了. 注意: ...

  4. Latex表格插入

    \begin{table}[h] \centering \caption{Traffic flows description} \begin{tabular}{|c||c|c|c|c|} \hline ...

  5. UVa 1610 Party Games(思维)

    题意: 给出一系列字符串,构造出一个最短字符串(可以不在集合中)大于等于其中的一半,小于另一半. 析:首先找出中间的两个字符串,然后暴力找出最短的字符串,满足题意. 代码如下: #include &l ...

  6. linux 定时器 定时执行php

    输入命令:    crontab -e 添加定时命令 每隔一分钟执行一次php //复制一下命令即可.  */1 * * * * /usr/bin/curl -o /home/logs/temp.lo ...

  7. 富文本粘贴word文档内容图片处理

    公司做的项目要用到文本上传功能. 网上找了很久,大部分都有一些不成熟的问题,终于让我找到了一个成熟的项目. 下面就来看看: 1.打开工程: 对于文档的上传我们需要知道这个项目是否符合我们的初衷. 运行 ...

  8. Eclipse sysout 和 fore 不起作用

    Content Assist ↑ 这是主角,可以快速生成语句. sysout 快捷键之后生成了 System.out.println(); fore 快捷键之后生成了 for(String arg : ...

  9. C#控件之:进度条(ProgressBar)

    一.重绘进度条 public class CustomProgressBar:ProgressBar { public CustomProgressBar() { this.SetStyle(Cont ...

  10. 20171126--idleHadnler的理解使用

    相关参考文献: http://www.jianshu.com/p/94d6131a53b2 http://bbs.51cto.com/thread-1094228-1.html https://zhu ...