一些必须要知道的概念

git的三个工作区域:工作目录、暂存区、git仓库。

工作目录:其实就是本地文件磁盘上的文件或目录;

暂存区:是一个文件,保存了下次提交的文件列表信息,一般在git仓库目录中;

git仓库:就是保存项目或文件的元数据和对象数据库的。其中包含了你提交给git的所有完整版本库。

基本的git工作流程如下:

  1. 在工作目录中修改文件。

  2. 暂存文件,将文件的快照放入暂存区域。

  3. 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 仓库目录。

创建一个git仓库

git init

进入你想要让git管理的目录,执行上面的命令,便初始化了一个git仓库。

这时,会在该目录下创建一个名为.git子目录,.git子目录下的文件其实就是git仓库的主要文件,一般不建议手动修改或删除它。

另外也可以从远程clone一个仓库到本地。

一般地,可以从github上clone一个你关注的项目下来。

git clone [url]

例如:git clone https://github.com/git/git.git

在git仓库中的一些基本操作

下面结合一个具体实例进行操作。

1、新建一个文件README.md,并交给git仓库管理。



可以看到我在mytestgit目录下先执行了git init 命令初始化了一个仓库。

然后新建了一个README.md文件。

此时,可以使用git status命令查看仓库状态。



可以看到有一个标红的文件是提示Untracked files,意思是还未交给git仓库跟踪管理,而且提示你可以使用git add命令来添加。

使用git add命令将文件添加到暂存区中。

git add README.md

继续使用git status命令查看状态



状态显示,当前在master分支,还未有过提交。提示下面绿色的文件可以提交或者从暂存区删除。

接下来,我们在新建一个test.txt文件,并使用git add命令交给git仓库跟踪。然后修改该文件,再查看状态。



出现在 Changes not staged for commit 这行下面的test.txt文件内容发生了变化,但是还未提交到暂存区中。如果要暂存这次修改,则需要继续运行git add命令。

因此,可以看到git add命令是多功能的,可以用它开始跟踪新文件,还能用它将已跟踪的文件再次放到暂存区中(即更新暂存区中的内容)。

2、使用git commit命令提交文件到git仓库

将上个步骤的两个文件我们提交到git仓库。

git commit -m "第一次提交新增了两个文件"



可以看到,提交后它会告诉你,当前是在哪个分支(master)提交的,本次提交的完整 SHA-1 校验和是什么(18350c3),以及在本次提交中,有多少文件修订过,多少行添加和删改过。

请记住,提交时记录的是放在暂存区域的快照。 任何还未暂存的仍然保持已修改状态,可以在下次提交时纳入版本管理。 每一次运行提交操作,都是对你项目作一次快照,以后可以回到这个状态,或者进行比较。

另外有一种方法可以跳过使用git add添加到暂存区然后再提交的方式。

即只要在提交的时候,给 git commit 加上 -a 选项,Git 就会自动把所有已经跟踪过的文件暂存起来一并提交,从而跳过 git add 步骤:

我们再次修改了test.txt文件,然后使用-a选项直接commit。

移除文件的操作

一种情况是从git仓库移除文件,同时删除磁盘上目录上的文件。

使用git rm完成,我们删除test.txt文件看下。



可以看到test.txt文件已经从被删除了。删除之后再使用git commit提交删除。



另外一种情况是,我们只想从git仓库中删除,但是仍然保留当前工作目录中的文件。可以使用--cached选项实现。

例如我们将版本库中的111.txt文件从版本库中删除,但是磁盘上的文件任然保留。

查看提交的历史记录

使用git log命令。



默认不用任何参数的话,git log 会按提交时间列出所有的更新,最近的更新排在最上面。 正如你所看到的,这个命令会列出每个提交的 SHA-1 校验和、作者的名字和电子邮件地址、提交时间以及提交说明。

git log 有许多选项可以帮助你搜寻你所要找的提交, 接下来我们介绍些最常用的。

一个常用的选项是 -p,用来显示每次提交的内容差异。 你也可以加上 -2 来仅显示最近两次提交:



还有--stat 选项在每次提交的下面列出所有被修改过的文件、有多少文件被修改了以及被修改过的文件的哪些行被移除或是添加了。 在每次提交的最后还有一个总结。



git log 的常用选项说明

撤销操作

1、工作区代码的撤销。

文件还未add到暂存区域,此时做出的修改可以通过git checkout -- <file>命令来撤销修改。

2、add到暂存区的代码想撤销

使用git reset HEAD <file>命令从暂存区撤销到工作区,然后再从工作区撤销。

3、提交到git仓库的代码回退

使用命令git reset --hard <版本号>

git基础命令详解的更多相关文章

  1. Git 常用命令详解

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  2. Git 常用命令详解(二)

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  3. 【转】 Git 常用命令详解(二)----不错

    原文网址:http://blog.csdn.net/ithomer/article/details/7529022 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如: ...

  4. git checkout 命令详解

    转自:http://www.cnblogs.com/hutaoer/archive/2013/05/07/git_checkout.html?utm_source=tuicool&utm_me ...

  5. git checkout 命令详解(转)

    在日常的git操作中,git checkout——检出,是我们的常用命令.最为常用的两种情形是创建分支和切换分支. 在下面的命令中,使用了一些简写,在这里说明一下: git st # git stat ...

  6. git checkout 命令详解【转】

    转自:http://www.cnblogs.com/hutaoer/archive/2013/05/07/git_checkout.html 在日常的git操作中,git checkout——检出,是 ...

  7. Linux基础命令详解-3

    本篇详解的命令有以下15个 1.chown 更改文件和文件夹的用户和组所有权 2.useradd 创建一个新用户 3.userdel 删除一个用户 4.usermod 修改用户帐户 5.echo 打印 ...

  8. Linux基础命令详解-2

    本篇详解的命令有以下30个 1.rmdir 功能:删除一个空目录   2.telnet 功能:使用telnet协议连接到主机的指定端口 3.vim 功能:编辑器之神 vim三种模式的功能及其转换   ...

  9. Linux基础命令详解-1

    本篇详解的命令有以下30个 1.cd 功能:切换工作目录 参数列表     2.ls 功能:查看目录里的内容 参数列表     3.mv 功能:  移动或重命名文件和目录 参数列表     4.pwd ...

随机推荐

  1. JavaScript如何给td赋值

    td里加个标签,如: <td><div id="aa"></div></td> document.getElementById('a ...

  2. 让Jenkins执行GitHub上的pipeline脚本

    本文是<Jenkins流水线(pipeline)实战>系列的第二篇,上一篇搭建好了Jenkins环境并执行了一个简单的pipeline任务,当时我们直接在Jenkins网页上编写pipel ...

  3. Windows10 系统更新之后找不到输入法

    是因为 , 系统更新之后 , 系统自带的输入法没有更新好 , 过个一两天,系统会自动修复. 简单解决办法是 , Ctrl+Alt+delete 打开任务管理器, 在进程中,按CPU大小排序,找到输入法 ...

  4. jps虚拟机进程状态工具

    jps(JVM Process Status Tool) jps工具可以列出正在运行的虚拟机进程,并显示虚拟机执行主类名称以及这些进程的本地虚拟机唯一ID(Local Virtual Machine ...

  5. 服务器替换san存储

    1.通知DBA停库: 串行登陆服务器 2.备份系统信息 mkdir -p /bakinfo df -h > /bakinfo/df.txt_`date +%Y%m%d%H%M%S` ps -ef ...

  6. IO、IO序列化

    文件:文件可认为是相关记录或放在一起的数据的集合.文件一般保存在硬盘.U盘.光盘.云盘的媒介中. JAVA API:java.io.File类可操作文件 File对象的构建 File file=new ...

  7. C++消息框架-基于sigslot

    目录 一.简介 二.消息 三.发送者 1.发送消息函数 2.新增一个接收者函数 3.移除一个接收者函数 四.接收者 五.功能测试 1.消息接收类 2.测试代码 3.测试结果 六.源码 一.简介 上一篇 ...

  8. React + TypeScript 默认 Props 的处理

    React 中的默认 Props 通过组件的 defaultProps 属性可为其 Props 指定默认值. 以下示例来自 React 官方文档 - Default Prop Values: clas ...

  9. Spark比MR快是因为在内存中计算?错!

    MapReduce 就像一台又慢又稳的老爷车,虽然距离 MapReduce 面市到现在已经过去了十几年的时间,但它始终没有被淘汰,任由大数据技术日新月异.蓬蓬勃勃.花里胡哨地发展,这个生态圈始终有它的 ...

  10. 迥异和诡异的SendMessage和PostMessage

    1       故障现象 故障现象1:能够收到SendMessage()发出的消息,但收不到PostMessage()发出的消息. 故障现象2:能够收到PostMessage()发出的消息,但收不到S ...