参考博文:廖雪峰Git教程

1. 工作区和暂存区

Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。

1.1. 工作区(Working Directory)

就是你在电脑里能看到的目录.比如:zhangtest

 [root@mini05 zhangtest]# pwd
/opt/git_repository/zhangtest
[root@mini05 zhangtest]# ll
total
-rw-r--r-- root root Sep : README.md
-rw-r--r-- root root Sep : test.info

1.2. 版本库(Repository)

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD

前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

测试实践

对README.md追加一些内容;新建LICENSE并添加内容。

 [root@mini05 zhangtest]# ll
total
-rw-r--r-- root root Sep : LICENSE
-rw-r--r-- root root Sep : README.md
-rw-r--r-- root root Sep : test.info
[root@mini05 zhangtest]#
[root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: README.md
#
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# LICENSE
no changes added to commit (use "git add" and/or "git commit -a")

由上可知:Git非常清楚地告诉我们,README.txt被修改了,而LICENSE还从来没有被添加过,所以它的状态是Untracked

现在,使用两次命令git add,把readme.txtLICENSE都添加后,用git status再查看一下:

 [root@mini05 zhangtest]# git add README.md
[root@mini05 zhangtest]# git add LICENSE
[root@mini05 zhangtest]#
[root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# new file: LICENSE
# modified: README.md
#

现在,暂存区的状态就变成这样了:

所以,git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。

 [root@mini05 zhangtest]# git commit -m "understand how stage works"
[master 53f0f2e] understand how stage works
files changed, insertions(+)
create mode LICENSE

一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的:

 [root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
nothing to commit, working directory clean

现在版本库变成了这样,暂存区就没有任何内容了:

2. 版本回退

在README.md追加了如下内容,并进行了提交。

 Git is a distributed version control system.
Git is free software distributed under the GPL.

提交

 [root@mini05 zhangtest]# vim README.md
# zhangtest
zhangtest
张三
Git is a distributed version control system.
Git is free software.
Git is a distributed version control system.
Git is free software distributed under the GPL.
[root@mini05 zhangtest]# git add . # 添加到暂存区
[root@mini05 zhangtest]# git commit -m "append GPL" # 提交到仓库

2.1. 查看版本日志信息

 # 使用 git add . 就是针对当前目录
[root@mini05 zhangtest]# git log README.md # 针对README.md文件
commit 9f27dce0f57cf811a8e3bdab545e8b98ca9bd41f
Author: Zhang San <zhanglianghhh@.com>
Date: Sun Sep :: + append GPL commit 65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e
Author: Zhang San <zhanglianghhh@.com>
Date: Mon Sep :: + add info commit d4fb57e8a892060db07fe862058a1a8477be49aa
Author: 张亮 <zhanglianghhh@.com>
Date: Mon Sep :: + Update README.md commit e7306765445375e4c1b52ebde07a666da5517b22
Author: 张亮 <zhanglianghhh@.com>
Date: Mon Sep :: + Initial commit

2.2. 简化版本日志

 [root@mini05 zhangtest]# git log --pretty=oneline README.md
9f27dce0f57cf811a8e3bdab545e8b98ca9bd41f append GPL
65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e add info
d4fb57e8a892060db07fe862058a1a8477be49aa Update README.md
e7306765445375e4c1b52ebde07a666da5517b22 Initial commit

2.3. 版本回退到65a58f2661

在Git中,用HEAD表示当前版本,也就是最新的提交9f27dce...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100

 # git reset --hard 65a58f2661  回退到指定版本,好处就是不用计算到底回退几个版本
[root@mini05 zhangtest]# git reset --hard HEAD^ # 回退到上一个版本
HEAD is now at 65a58f2 add info
[root@mini05 zhangtest]# cat README.md # 查看内容,可见以回退到上一个版本
# zhangtest
zhangtest
张三
Git is a distributed version control system.
Git is free software.
[root@mini05 zhangtest]# git log --pretty=oneline README.md # 根据提交日志,也可知已回退
65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e add info
d4fb57e8a892060db07fe862058a1a8477be49aa Update README.md
e7306765445375e4c1b52ebde07a666da5517b22 Initial commit

2.4. 回退原理

Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,当你回退版本的时候,Git仅仅是把HEAD从指向append GPL

改为指向add info

然后顺便把工作区的文件更新了。所以你让HEAD指向哪个版本号,你就把当前版本定位在哪。

2.5. 记录每一次命令

回退到了某个版本,想恢复到新版本怎么办?找不到新版本的commit id怎么办?

Git提供了一个命令git reflog用来记录你的每一次命令:

git reflog查看命令历史,以便确定要回到未来的哪个版本。

 [root@mini05 zhangtest]# git reflog
65a58f2 HEAD@{}: reset: moving to 65a58f2661
9f27dce HEAD@{}: reset: moving to 9f27dce0f57cf
65a58f2 HEAD@{}: reset: moving to HEAD^
9f27dce HEAD@{}: commit: append GPL
65a58f2 HEAD@{}: commit: add info
d4fb57e HEAD@{}: pull git@github.com:zhanglianghhh/zhangtest.git: Fast-forward
e730676 HEAD@{}: clone: from git@github.com:zhanglianghhh/zhangtest.git

GitHub-暂存区与版本回退的更多相关文章

  1. [git]入门-工作区、暂存区、版本库

    转载整理自:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256 ...

  2. git工作区、暂存区、版本库之间的关系

    区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...

  3. 【Git】(1)---工作区、暂存区、版本库、远程仓库

    工作区.暂存区.版本库.远程仓库 一.概念 1.四个工作区域 Git本地有四个工作区域:工作目录(Working Directory).暂存区(Stage/Index).资源库(Repository或 ...

  4. 【原创】Git删除暂存区或版本库中的文件

    0 基础     我们知道Git有三大区(工作区.暂存区.版本库)以及几个状态(untracked.unstaged.uncommited),下面只是简述下Git的大概工作流程,详细的可以参见本博客的 ...

  5. Git工作区、暂存区和版本库

    基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".git目录下" 下的in ...

  6. Git 工作区、暂存区和版本库

    基本概念 我们等来理解下Git工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录 强烈推荐git新手阅读 暂存区:英文叫stage,或index.一般存放在igt 目录下的index文件( ...

  7. Git-Runoob:Git 工作区、暂存区和版本库

    ylbtech-Git-Runoob:Git 工作区.暂存区和版本库 1.返回顶部 1. Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电 ...

  8. Git 工作区、暂存区和版本库、操作流程

    Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".g ...

  9. 【第四篇】-Git 工作区、暂存区和版本库之Spring Cloud直播商城 b2b2c电子商务技术总结

    Git 工作区.暂存区和版本库 基本概念 我们先来理解下 Git 工作区.暂存区和版本库概念: 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫 stage 或 index.一般存放在 .git  ...

随机推荐

  1. [PKUWC2018] Minimax

    Description 给定一棵 \(n\) 个节点的树,每个节点最多有两个子节点. 如果 \(x\) 是叶子,则给定 \(x\) 的权值:否则,它的权值有 \(p_x\) 的概率是它子节点中权值的较 ...

  2. 【golang-GUI开发】Qt5的安装

    golang一直被认为没有好的GUI库,事实并非如此. 目前有基于gtk+3.0的gotk3:https://github.com/gotk3/gotk3 以及接下来我们要说的qt:https://g ...

  3. C#中saveFileDialog(另存为)保存图片文件

    弹出另存为提示框保存图片文件: //用户自由选择指定路径保存文件            SaveFileDialog savedialog = new SaveFileDialog();        ...

  4. Java 学习笔记 泛型

    泛型 上界匹配 ? extends Number 下界匹配 ? super Number getSimpleName 不包括包名 getName 会包括包名 常和反射联合使用,做框架 Type是一个标 ...

  5. clean 伪目标

    下面的"clean"目标,是一个"伪目标",      clean:              rm *.o temp  我们生成了许多文件编译文件,我们也应该 ...

  6. Yii2基本概念之——事件(Event)

    说起事件(event),我们可是一点都不陌生.现实生活当中的事件无处不在,比如你发了一条微博,触发了一条事件,导致关注你的人收到了一条消息,看到你发的内容:比如你通过支付宝买东西,付了款,触发一个事件 ...

  7. (一):C++分布式实时应用框架----整体介绍

    C++分布式实时应用框架 (Cpp Distributed Real-time Application Framework) 版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经 ...

  8. css 表单标签两端对齐

    来自:http://demo.doyoe.com/css3/justify/justify-form.htm  侵删 <!DOCTYPE html> <html lang=" ...

  9. elementUI vue v-model的修饰符

    v-model的修饰符 v-model.lazy 只有在input输入框发生一个blur时才触发 v-model.trim 将用户输入的前后的空格去掉 v-model.number 将用户输入的字符串 ...

  10. Vue2+VueRouter2+webpack 构建项目实战(三):配置路由,运行页面

    制作.vue模板文件 通过前面的两篇博文的学习,我们已经建立好了一个项目.问题是,我们还没有开始制作页面.下面,我们要来做页面了. 我们还是利用 http://cnodejs.org/api 这里公开 ...