参考博文:廖雪峰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. C 程序与 C++ 程序之间的相互调用

    因为 C 编译器编译函数时不带参数的类型信息,只包含函数的符号名字.如 void foo( int x ) , C 编译器会将此函数编译成类似 _foo 的符号,C 链接器只要找到了调用函数的符号,就 ...

  2. Raft 基础

    目录 三个状态 什么是任期 节点之间的通信 1. 三个状态 Raft 设计了 3 个状态,用于表示节点的状态,分别是跟随者,候选者,领导者. 领导者:通常只有一个领导人,并且其他节点都是跟随者. 跟随 ...

  3. Keras入门(二)模型的保存、读取及加载

    本文将会介绍如何利用Keras来实现模型的保存.读取以及加载.   本文使用的模型为解决IRIS数据集的多分类问题而设计的深度神经网络(DNN)模型,模型的结构示意图如下: 具体的模型参数可以参考文章 ...

  4. Java集合性能分析-疯狂Java讲义

    一.各Set实现类的性能分析 HashSet和TreeSet是Set的两个典型实现.HashSet的性能总是比TreeSet好(特别是最常用的添加.查询元素等操作),因为TreeSet需要额外的红黑树 ...

  5. Eclipse中SVN插件的安装和配置(离线安装)

    Eclipse利用svn的离线安装包进行配置svn,这种方式配置起来很简单,但是前提是必须下载可用的的svn离线包.因为有的从网上下载的svn离线包有问题. 第一步:下载svn离线包 我下载的是下面这 ...

  6. 小兔的棋盘(hdu2067)

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  7. Java基础IO流(四)序列化与反序列化

    对象的序列化与反序列化: 对象的序列化,就是将Object转换成byte序列,反之叫对象的反序列化. 序列化流(ObjectOutInputStream),是过滤流 -------writeObjec ...

  8. SpringBoot 之基础学习篇.

    一.概念简介 SpringBoot 的关键词是“约定俗成”,它根据长久以来的 Spring 开发配置经验,整理出一套适用.普遍.大家都认可的配置方案.所以 SpringBoot 的学习过程中心态一定要 ...

  9. Netty 系列二(传输).

    一.前言 上一篇文章我们提到 Netty 的核心组件是 Channel.回调.Future.ChannelHandler.EventLoop,这篇文章主要是对 Channel (Netty传入和传出数 ...

  10. JavaScript学习备忘

    1.您只能在 HTML 输出流中使用 document.write 如果在文档已加载后使用它(比如在函数中),会覆盖整个文档 2.数组 : [40, 100, 1, 5, 25, 10] <== ...