参考博文:廖雪峰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. MySQL系列详解九:MySQL级联复制演示-技术流ken

    前言 级联复制就是master服务器,只给后端一台slave服务器同步数据,然后这个slave服务器在向后端的所有slave服务器同步数据,这样就可以降低master服务器的写压力,和复制数据的网络I ...

  2. [日常]总结2016年7月入职至2016年7月26号微盘所遇bug

    2016年刚入职后在新浪微盘项目上所遇到的问题: 1.前端接口的程序不同版本问题,版本号在程序路径中区分,比如2.4.2/lib/sdk/api/weipan/Client.php 2.文件夹接口的m ...

  3. Flask 系列之 FlaskForm

    通过使用 FlaskForm ,可以方便快捷的实现表单处理. 说明 操作系统:Windows 10 Python 版本:3.7x 虚拟环境管理器:virtualenv 代码编辑器:VS Code 实验 ...

  4. JavaScript是如何工作的:Service Worker的生命周期及使用场景

    摘要: 理解Service Worker. 原文:JavaScript 是如何工作的:Service Worker 的生命周期及使用场景 作者:前端小智 Fundebug经授权转载,版权归原作者所有. ...

  5. Andorid 刷新样式一

    一.Gradle中的Build.gradle依赖项目 compile 'com.github.moduth:blockcanary-android:1.1.0' debugCompile 'com.s ...

  6. Ehcache配置详解及CacheManager使用

    <?xml version="1.0" encoding="UTF-8"?><ehcache xmlns:xsi="http://w ...

  7. Jedis 简单案例

    POM 依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> <dependency> < ...

  8. phpcms中content主要使用的详情列表关系

    从首页(index.html)中点开的内容网页叫单网页(page.html) 从列表(list.html)中点开的网页叫内容页(show.html) 从导航栏的栏目中下拉的列表栏目叫栏目列表页(cat ...

  9. Android为TV端助力 Canvas 和 Paint用法

    自定义view里面的onDraw方法,在这里我们可以绘制各种图形,onDraw里面有两个API我们需要了解清楚他们的用法:Canvas 和 Paint. Canvas翻译成中文就是画布的意思,Canv ...

  10. ionic提示弹框

    //提示框 .factory('TipsPort', function ($ionicPopup) { var TipsPort = function (tipsText, SureFunction, ...