`

Git的入门(1)

    博客分类:
  • Git
 
阅读更多


本博客完全参考廖雪峰的官方网络

http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

 

1.创建版本库

2.时光机穿梭

2.1版本回退

2.2工作区和暂存区

2.3管理修改

2.4撤销修改

2.5删除文件

 

 

1.创建版本库

 

 

新建一个文件夹,我是在E盘创建了一个Git文件夹

 


 

pwd 命令用于显示当前目录。在我的电脑上,仓库位于E:/Git/learnight

为了避免出现各种莫名其妙的问题,请确保该目录中不含中文。

 

第二步,通过git init命令把这个目录变成Git可以管理的仓库:

 


 

此时Git就把仓库建好了,

 

用ls -ah命令可以看到隐藏的.git文件



 

该文件是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里的文件,不然改乱了,就把Git仓库给破坏了。

 

把文件添加到版本库

 

这里说明一下,千万不要用windows自带的记事本编辑任何文本文件。用Notepad++来编写。

记得把Notepad++的默认编码设置为UTF-8 without BOM即可:

 


 

言归正传,现在我们编写一个readme.txt文件,内容如下:

 

Git is a version control system.
Git is free software

 

 将该文件存放到learngit文件里。

 

第一步:用命令git add 告诉Git,把文件添加到仓库



 

执行上面的命令,没有任何显示,就对了,说明添加成功。

第二步:用命令git commit告诉Git,把文件提交到仓库。



 

git commit命令,-m后面输入的是本次提交的说明,可以输入任何内容,当然为了日后方便查找,最好是有意义的。

 

git commit命令执行成功后会告诉你,1个文件被改动(我们新添加的readme.txt文件),插入了两行内容(readme.txt有两行内容)

 

为什么Git添加文件需要addcommit一共两步呢?因为commit可以一次提交很多文件,所以你可以多次add不同的文件,比如:

 



 

 

小结:

1.初始化一个Git仓库,使用git init命令

2.添加文件到Git仓库,分为两步:

   第一步:使用命令git add <file>,注意,可反复多次使用,添加多个文件;

   第二步:使用命令git commit,完成。

 

 

2.时光机穿梭

修改readme.txt文件

Git is a distributed version control system.
Git is free software.

输入git status命令查看结果:

 

 

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

 

使用git diff查看具体修改了什么内容



 

git diff顾名思义就是查看difference,从输出可以看到我们在第一行添加了一个"distributed"单词。

 

将修改后的readme.txt提交



 

运行git status看看当前仓库的状态



 

git status告诉我们,将要被提交的修改包括readme.txt,下一步,就可以放心地提交了:



 

提交后,我们再用git status命令看看仓库的当前状态:

 


 

git告诉我们当前没有需要提交的修改,而且,工作目录是干净的。

 

小结:

要随时掌握工作区的状态,使用git status命令。

如果git status告诉你有文件被修改过,用git diff可以查看修改内容。

 

2.1版本回退

 

修改readme.txt文件如下:

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

然后尝试提交:

 


 

每当你觉得文件修改到一定程度的时候,就可以“保存一个快照”,这个快照在git中被称为commit。一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复。

现在,我们回顾一下readme.txt文件一共有几个版本被提交到git仓库里:

版本1:wrote a readme file

Git is a version control system.
Git is free software.

 版本2:add distributed

Git is a distributed version control system.
Git is free software.

版本3:append GPL

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

 版本控制系统中的git log命令可以查看修改的历史纪录:



git log命令显示从最近到最远的提交日志,我们可以看到3次提交,最近的一次是append GPL,上一次是add distributed,最早的一次是wrote a readme file。

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数:


 11c94d536fc2b0a58d52f76dc1687f192bc47b97是commit id(版本号)

 现在我们启动时光穿梭机,准备把readme.txt回退到上一个版本,也就是“add distributed"的那个版本,怎么做呢?

首先,Git必须知道当前是哪个版本,在git中,用HEAD表示当前版本,也就是最新的提交11c94d536fc2b0a58d52f76dc1687f192bc47b97,上一个版本就HEDA^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

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


看看readme.txt的内容是不是版本add distributed:

查看内容用cat命令


用git log再看看现在版本库的状态:



最新的那个版本append GPL已经看不到了,此时你只能通过append GPL的commit id是 11c94d536fc2b0a58d52f76dc1687f192bc47b97。


再看看readme.txt的内容:


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



 

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

但,当你找不到新版本的commit id怎么办?

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


第三行显示append GPL的commit id是11c94d5,现在,你又可以乘坐时光机回到未来了。

小结:

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

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

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

 

2.2工作区和暂存区

工作区(working directory)

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

版本库(repository)

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

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

把文件往git版本库里添加的时候,是分两步执行的:

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

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

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

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

下面对readme.txt做个修改,比如加上一行内容:

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.

然后,在工作区新增一个LICENSE文本文件(内容随便写)

先用git status查看一下状态:


git告诉我们,readme.txt被修改了,而LICENSE还从来没有被添加过,所以它的状态是Untracked。

现在,使用两次命令git add,把readme.txt和LICENSE都添加。




用git status再查看一下:


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


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


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


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


小结:

暂存区是git非常重要的概念,弄明白了暂存区,就弄明白了git的很多操作到底干了什么。

 

2.3管理修改

git跟踪器管理的是修改,而非文件。

那么,什么是修改?比如你新增了一行,这就是一个修改,删除了一行,也是一个修改,更改了某些字符,也是一个修改,删了一些又加了一些,也是一个修改,甚至创建一个新文件,也算一个修改。

下面,对readme.txt做一个修改,比如加一行内容:

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes.

查看:


添加:


查看状态:


然后,再修改readme.txt

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.

查看:


然后,添加:


查看状态:


然后,再修改readme.txt

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.

 查看、提交:


 看状态:

发现第二次的修改没有被提交。

我们回顾一下操作过程:

第一次修改->git add->第二次修改->git commit

git 管理的是修改,当你用git add命令后,在工作区的第一次修改被放入暂存区,准备提交,但是,在工作区的第二次修改并没有放入暂存区,所以,git commit只负责把暂存区的修改提交了,也就是第一次的修改被提交了,第二次的修改不会被提交。

提交后,用git diff HEAD -- readme.txt命令可以查看工作区和版本库里面的最新版本的区别:


可见,第二次修改确实没有被提交。

那怎么提交第二次修改呢?

你可以继续git add再git commit,也可以别着急提交第一次修改,先git add第二次修改,再git commit,就相当于合并后一块提交了:第一次修改->git add->第二次修改->git add->git commit

 

2.4撤销修改

在readme.txt中添加一行

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.
My stupid boss still prefers SVN.

 查看:


你可以删掉最后一行,手动把文件恢复到上一个版本。

如果用git status看一下:


Git告诉你,git checkout --file可以丢弃工作区的修改:


命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:

一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;

一种是readme.txt已经添加到暂存区,又作了修改,现在,撤销修改就回到添加暂存区后的状态。

总之,就是让这个文件回到最近一次git commit或git add时的状态。

现在,看看readme.txt的文件内容:


文件内容果然复原了。

假定你现在修改readme.txt的内容如下,并且还git add到暂存区:


庆幸的是,在commit之前,你发现了这个问题。用git status查看一下,修改只是添加到了暂存区,还没有提交:


Git同样告诉我们,用命令git reset HEAD file可以把暂存区的修改撤销掉(unstage),重新放回工作区。


git  reset命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD时,表示最新的版本。

再用git status查看一下,现在暂存区是干净的,工作区有修改:


还记得如何丢去工作区的修改吗?


小结:

场景一:当你乱改了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。

场景二:当你不但该乱了工作区的某个文件的内容,还添加到了暂存区,想丢弃修改,分两步,第一步用命令git reset HEAD file,回到场景一,第二步按场景一操作。

场景三:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

 

2.5删除文件

 

在Git中,删除也是一个修改操作,先添加一个新文件test.txt到Git并且提交:


一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:


这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了:


现在你有两个选择,一是确实要从版本库中删除该文件,那就命令git rm删掉,并且git commit:


现在,文件就从版本库中被删除了。

另一种情况是删除了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:

$ git checkout -- test.txt

git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以一键还原。

小结:

命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复到最新版本,你会丢弃最近一次提交后你修改的内容。

 

 

 

 

 

 

 

 

 

 

 

 

  • 大小: 13.1 KB
  • 大小: 4.4 KB
  • 大小: 4 KB
  • 大小: 30 KB
  • 大小: 3.8 KB
  • 大小: 6.3 KB
  • 大小: 11.9 KB
  • 大小: 11.2 KB
  • 大小: 12.7 KB
  • 大小: 5.5 KB
  • 大小: 8.3 KB
  • 大小: 4.9 KB
  • 大小: 6.6 KB
  • 大小: 10.4 KB
  • 大小: 43.7 KB
  • 大小: 9.7 KB
  • 大小: 7 KB
  • 大小: 6.7 KB
  • 大小: 20.7 KB
  • 大小: 5.1 KB
  • 大小: 4.6 KB
  • 大小: 22.4 KB
  • 大小: 23.1 KB
  • 大小: 14.2 KB
  • 大小: 42.3 KB
  • 大小: 11.2 KB
  • 大小: 3 KB
  • 大小: 3.2 KB
  • 大小: 6.1 KB
  • 大小: 40.8 KB
  • 大小: 5.9 KB
  • 大小: 4.2 KB
  • 大小: 40.5 KB
  • 大小: 5.7 KB
  • 大小: 3.1 KB
  • 大小: 5.6 KB
  • 大小: 5.7 KB
  • 大小: 3.1 KB
  • 大小: 5.7 KB
  • 大小: 10.3 KB
  • 大小: 8.7 KB
  • 大小: 12.2 KB
  • 大小: 6.9 KB
  • 大小: 8.7 KB
  • 大小: 3.3 KB
  • 大小: 5.8 KB
  • 大小: 9.6 KB
  • 大小: 5.6 KB
  • 大小: 4.3 KB
  • 大小: 8.7 KB
  • 大小: 7.3 KB
  • 大小: 8.4 KB
  • 大小: 2.9 KB
  • 大小: 8.7 KB
  • 大小: 8.5 KB
分享到:
评论

相关推荐

    git入门培训pptgit入门培训ppt

    git入门培训ppt,git使用培训,git发展,git分支的使用,git中的基本使用说明和以及基本命令, git入门培训ppt,git使用培训,git发展,git分支的使用,git中的基本使用说明和以及基本命令

    猴子都能懂的Git入门-整站

    "猴子都能懂的Git入门-整站"是一个专门为初学者设计的Git学习资源,旨在用简单易懂的方式讲解Git的基础知识,并逐步引导进阶到高级应用。 入门篇主要涵盖以下内容: 1. Git安装:讲解如何在Windows、Mac OS X和...

    猴子都能懂的GIT入门

    "猴子都能懂的GIT入门"这个主题,旨在让初学者,甚至是对技术不太熟悉的人都能轻松理解Git的基本概念和操作。Git的核心价值在于它能够跟踪代码的历史版本,允许团队成员在不影响主分支的情况下各自开发,然后通过...

    猴子都能懂的Git入门 HTML整站离线 2017-07

    "猴子都能懂的Git入门"这个标题暗示了这是一个适合初学者的Git教程,旨在用易于理解的方式介绍Git的基础知识。下面将详细阐述Git的核心概念和常用操作。 1. **Git基础概念**: - **仓库(Repository)**:Git中的...

    Git入门到实践

    Git入门到实践 高清 有目录

    Git入门指南(Git新人入门必看)

    例如,`git branch`用于管理分支,`git merge`用于合并分支,`git log`查看提交历史,`git reset`回退到某个版本,以及`git push`和`git pull`用于与远程仓库交互。理解并熟练掌握这些命令,将使你在Git的世界中...

    Git入门学习资料.zip

    Git入门学习资料 包括如下文档: Git.pdf git-tutor.pdf progit.zh.pdf

    猴子都能懂的GIT入门.pdf

    将网页版的猴子都能懂的GIT(https://backlog.com/git-tutorial/cn/)转换成PDF格式,并且已添加书签,感谢这个作者编写的教程

    猴子都能懂的Git入门-html版

    "猴子都能懂的Git入门-html版"是一个专为初学者设计的教程,它以易于理解的方式介绍了Git的基础知识,包括卡通示例图,使得学习过程更加直观和有趣。 Git的核心概念包括仓库(Repository)、分支(Branch)、提交...

    Git教程 从入门到精通

    ### Git教程从入门到精通——知识点详解 #### 一、Git简介 - **Git是什么**:Git是一款目前世界上最先进的分布式版本控制系统。它被设计用于高效处理从小型到大型项目的版本控制,尤其适合软件开发项目。 - **Git...

    Git快速入门学习.pdf

    Git提供了很多命令,如git init初始化仓库、git add添加文件到暂存区、git commit将暂存区的更改提交到仓库、git push把本地更改推送到远程仓库,以及git pull从远程仓库获取并合并到本地。 除了基本的命令之外,...

    git入门级别教材

    学习git的直通车,git入门必备。

    git入门笔记

    git入门笔记, 基本操作,主要记录了学习git的过程使用到饿一些基本命令,比如常见的git pull, git push, git status, git log等

    03Git入门Git初始设定 git init

    03★Git入门★Git初始设定_git_init

    GIT教程_git入门_git_

    本教程绝对面向初学者,没有接触过版本控制概念的读者也可以轻松入门,不必担心起步难度;

    git入门文档(适合git入门学者,资料比较全)

    本文档旨在为git入门学者提供全面的基础知识和实用技巧,帮助安卓手机开发者更好地理解和应用git。 1. **Git基础概念** - **版本控制**:Git的核心功能是管理文件的不同版本,它记录每一次修改,便于回溯和协作。 ...

    Git实战入门.docx

    总的来说,这份文档提供了一个全面的Git入门指南,涵盖了从安装到实际操作的所有基本步骤,对于初学者来说是一份非常实用的学习资源。配合提供的视频教程,学习者可以更直观地理解Git的工作原理和实践操作。

    Git中文学习手册 Git入门

    1 2 Git 简史 1 3 Git 基础 1 4 安装 Git 1 5 初次运行 Git 前的配置 1 6 获取帮助 1 7 小结 2 Git 基础 2 1 取得项目的 Git 仓库 2 2 记录每次更新到仓库 2 3 查看提交历史 2 4 撤消操作 2 5 远程仓库的...

Global site tag (gtag.js) - Google Analytics