2.git版本控制-时光机穿梭

把上一节test.txt的内容修改为:Today is 2015-8-21

运行git status命令看看(注意用cd d:/mygit 跳转到你上一节所建的目录,如果你关闭过命令窗口)

$ git status
On branch master
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:   test.txt

no changes added to commit (use "git add" and/or "git commit -a")

git status命令可以让我们时刻掌握仓库当前的状态,上面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。

虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用git diff这个命令看看:

$ git diff test.txt
diff --git a/test.txt b/test.txt
index 273c1a9..fea69bb 100644
--- a/test.txt
+++ b/test.txt
@@ -1 +1 @@
-This is a test.
\ No newline at end of file
+Today is 2015-8-21
\ No newline at end of file

再运行git add "test.txt"和git commit -m "20150821modify"命令

版本回退  运行$ git log查看修改的历史记录,或$ git log --pretty=oneline

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

现在,我们要把当前版本“append GPL”回退到上一个版本“add distributed”,就可以使用git reset命令:

$ git reset --hard HEAD~
显示回退成功:HEAD is now at 5376f91 20150821modify

$ cat test.txt

显示上一个版本的内容:Today is 2015-8-21

现在总结一下:

  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id

  • 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。

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

工作区(Working Directory)

就是你在电脑里能看到的目录,比如我的mygit文件夹就是一个工作区:

版本库(Repository)

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

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

 

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

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

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

因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。

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

查看原教程


转自http://www.liaoxuefeng.com

教程推荐:Pro Git(中文版) http://jingxuan.io/progit/

posted @ 2015-08-22 17:48  农村人也爱编程  阅读(207)  评论(0编辑  收藏  举报