一些必须要知道的概念

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. JSP获取网络IP地址

    import javax.servlet.http.HttpServletRequest; public class RemoteAddress { public static String getR ...

  2. python 虚拟环境下导入模块出现no matching modules 的解决办法

    问题原因:pip版本过低 解决办法:升级pip                             命令行为   python -m pip install -U pip

  3. POA理论:不要被你的目标欺骗了你

    ![](https://img2018.cnblogs.com/blog/330316/201909/330316-20190922210844977-255725510.jpg) 最近通过<跃 ...

  4. java中的逃逸分析

    逃逸分析 public static StringBuffer craeteStringBuffer(String s1, String s2) { StringBuffer sb = new Str ...

  5. 【Jsp】利用iframe实现action不跳转

    <form role="form" target="id_frame" action="dk" method="post&q ...

  6. 第八届蓝桥杯java b组第三题

    标题:承压计算 X星球的高科技实验室中整齐地堆放着某批珍贵金属原料. 每块金属原料的外形.尺寸完全一致,但重量不同.金属材料被严格地堆放成金字塔形. 7                         ...

  7. [技术栈]CRC校验原理及C#代码实现CRC16、CRC32计算FCS校验码

    1.CRC.FCS是什么 CRC,全称Cyclic Redundancy Check,中文名称为循环冗余校验,是一种根据网络数据包或计算机文件等数据产生简短固定位数校验码的一种信道编码技术,主要用来检 ...

  8. win10下安装FFmpeg步骤

    1.官方下载地址:https://ffmpeg.zeranoe.com/builds/ # 下载方式一,太慢 # 下载方式二,推荐 2.解压到D:\Program Files (x86),这个看个人喜 ...

  9. JVM 调优 - jstat

    Java命令学习系列(四)——jstat 2015-07-31 分类:Java 阅读(11041) 评论(1) 阿里大牛珍藏架构资料,点击链接免费获取 jstat(JVM Statistics Mon ...

  10. Hadoop源代码点滴-自然常数e

    数学里的 e 为什么叫做自然底数?是不是自然界里什么东西恰好是 e? https://www.zhihu.com/question/20296247