git基础命令详解
一些必须要知道的概念
git的三个工作区域:工作目录、暂存区、git仓库。
工作目录:其实就是本地文件磁盘上的文件或目录;
暂存区:是一个文件,保存了下次提交的文件列表信息,一般在git仓库目录中;
git仓库:就是保存项目或文件的元数据和对象数据库的。其中包含了你提交给git的所有完整版本库。
基本的git工作流程如下:
在工作目录中修改文件。
暂存文件,将文件的快照放入暂存区域。
提交更新,找到暂存区域的文件,将快照永久性存储到 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基础命令详解的更多相关文章
- Git 常用命令详解
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
- Git 常用命令详解(二)
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
- 【转】 Git 常用命令详解(二)----不错
原文网址:http://blog.csdn.net/ithomer/article/details/7529022 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如: ...
- git checkout 命令详解
转自:http://www.cnblogs.com/hutaoer/archive/2013/05/07/git_checkout.html?utm_source=tuicool&utm_me ...
- git checkout 命令详解(转)
在日常的git操作中,git checkout——检出,是我们的常用命令.最为常用的两种情形是创建分支和切换分支. 在下面的命令中,使用了一些简写,在这里说明一下: git st # git stat ...
- git checkout 命令详解【转】
转自:http://www.cnblogs.com/hutaoer/archive/2013/05/07/git_checkout.html 在日常的git操作中,git checkout——检出,是 ...
- Linux基础命令详解-3
本篇详解的命令有以下15个 1.chown 更改文件和文件夹的用户和组所有权 2.useradd 创建一个新用户 3.userdel 删除一个用户 4.usermod 修改用户帐户 5.echo 打印 ...
- Linux基础命令详解-2
本篇详解的命令有以下30个 1.rmdir 功能:删除一个空目录 2.telnet 功能:使用telnet协议连接到主机的指定端口 3.vim 功能:编辑器之神 vim三种模式的功能及其转换 ...
- Linux基础命令详解-1
本篇详解的命令有以下30个 1.cd 功能:切换工作目录 参数列表 2.ls 功能:查看目录里的内容 参数列表 3.mv 功能: 移动或重命名文件和目录 参数列表 4.pwd ...
随机推荐
- Winform中设置ZedGraph曲线图的水平与竖直参考线
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- mysql解压版服务启动方式
使用mysql解压版,在不安装为windows服务时,使用下面的方式启动. 1.打开命令行,首先进入mysql解压目录的bin目录下 d:\mysql\bin 2.输入mysqld --console ...
- Python集训营45天—Day04 (函数)
目录 1. 函数介绍 2. 函数的参数 3. 模块与函数 4. 递归函数 5. 匿名函数 6. 多返回值 python 的学习已经进入到第四天,前面几章我们已经学会了基本的变量操作,以及分支结构和循环 ...
- thinkphp6 常用方法文档
请求变量 use think\facade\Request; Request::param('name'); Request::param();全部请求变量 返回数组 Request::param([ ...
- Android开发--Intent的使用(1)启动活动
Android系统是目前世界上市场占有率最高的移动操作系统,近年来,Android开发也越来越炙手可热. 在Android开发中,我们使用Intent进行活动Activity之间穿梭. 当我们点击启动 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业
1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...
- cent OS 7 忘记 root 密码
1. 在如下图, 选择系统的界面 按 e 2. 移动光标到文件底部, 修改如下两个地方(初始化 shell文件 并设置可读写), Ctrl x 退出并启动 shell 3. 如下界面 输入命令 mou ...
- 【原创】如何根据日志来估算线上QPS
引言 大家好,我是渣渣烟. 我又来水文章了.这篇文章我个人感觉含金量不是太大,大概5分钟左右就能看完!其实大家都知道,我不爱写这种操作型的文章,一顿截图写几个命令就搞定了,含金量不高. 然而,近期有一 ...
- 10 大 python 库
TensorFlow Scikit-Learn Numpy Keras PyTorch LightGBM Eli5 SciPy Theano Pandas 简介 python 是最流行和使用最广泛的编 ...
- hihttps教你在Wireshark中提取旁路https解密源码
大家好,我是hihttps,专注SSL web安全研究,今天本文就是教大家怎样从wireshark源码中,提取旁路https解密的源码,非常值得学习和商业应用. 一.旁路https解密条件 众所周知, ...