![](https://img.haomeiwen.com/i13496666/1cb0efab6b91b6b8.png)
—— 安装git
直接在官网:https://www.git-scm.com/ 进行下载,安装步骤一直continue就可以了,比较容易。
—— 配置
安装之后需要配置,往全局配置,以后建立的所有项目都会默认使用这个配置。
git config --global user.name "xxx" # 名字
git config --global user.email "xxx@gmail.com" # 邮箱,怎么联系你
我们配置好之后也可以查看当前的所有配置信息
命令:git config --list | l --查看所有配置信息
—— git操作①
首先我们新建一个目录用来测试
![](https://img.haomeiwen.com/i13496666/1edad3e83e5f43da.png)
进入到test1目录里头,现在它只是系统的一个文件
命令:git init --初始化
![](https://img.haomeiwen.com/i13496666/4aba159c7f1ccb88.png)
初始化了一个空的git仓库,我们使用 ls -a命令可以查看当前目录所有文件,我们发现多了一个git子目录,我们可以不用去管这个git子目录,git自己知道怎么使用
![](https://img.haomeiwen.com/i13496666/ab0c83e433e63cb3.png)
我们也可以在初始化的时候跟上一个目录名,在创建目录的同时创建一个仓库,相对于第一种是手动新建目录
命令:git init 文件名
![](https://img.haomeiwen.com/i13496666/a5d8221134d4651a.png)
我们还可以在github直接克隆下来
![](https://img.haomeiwen.com/i13496666/8eb6f4b08448dd82.png)
命令:git clone https://github.com/...../cleverhans.git [命名] # 下载下来的新命名
![](https://img.haomeiwen.com/i13496666/11ffa73c273842bc.png)
—— git操作②
我们再新建一个仓库之后里面什么也没有,我们就可以使用命令查看仓库
命令:git status --查看仓库状态
![](https://img.haomeiwen.com/i13496666/6fbf033a5f079746.png)
我们可以把Commits当作后悔药的意思,这是一个历史节点,现在里面没有一条历史记录,这时我们新建一个文件再查看一下状态
![](https://img.haomeiwen.com/i13496666/91358b013efd8cff.png)
Untracked file(未跟踪的文件),当前这个仓库有文件更改了,但是我们还没造后悔药,很可能以后丢失了我们就找不回来了。
命令:git add . --将所有修改添加至暂存区
![](https://img.haomeiwen.com/i13496666/76bac7270ddbec7e.png)
这时候我们在查看一下仓库状态,发现t1.txt文件变绿了
命令:git commit -m "描述" --提交版本
![](https://img.haomeiwen.com/i13496666/e324ce6632d0ce07.png)
现在你所有的更改都保存了,从上一次造后悔药到现在为止你还没有更改东西呢,一切都是安全的,基本是这个意思,假设我们有很多个版本,那我们要怎样查询所有呢?
命令:git log --查看版本记录
命令:git log --oneline --查看一行
![](https://img.haomeiwen.com/i13496666/3f286b5d3837e995.png)
commit后边有一串数字,可以理解为这颗后悔药的身份证号,可以用于绝对定位历史节点,按下q就可以退出
然后我们往t1.txt里头添加一些内容
![](https://img.haomeiwen.com/i13496666/578f786a7b857668.png)
![](https://img.haomeiwen.com/i13496666/0db8905fb4eea402.png)
我们再查看一下仓库状态,我们发现文件更改了
![](https://img.haomeiwen.com/i13496666/d6fac3984cbf50d6.png)
我们再把文件添加到暂存区,我们又造了一颗后悔药,我们发现用于定位的身份证号(fca4c93)跟刚刚看的相差很多位数,其实7位也可以定位。
![](https://img.haomeiwen.com/i13496666/c4206d32984508dd.png)
可以发现又多了一颗后悔药,我们可以把身份证号复制粘贴上去查询,看一看当时版本是个什么样子的
命令:git checkout fca4c93 --穿越到指定的历史节点 | git chechout - --回到上一个节点
![](https://img.haomeiwen.com/i13496666/5eb4def076ef9128.png)
现在又有一个问题,假设我们修改文件,但是我们查看日志并不能告诉我们哪里修改了,我们可以
命令:git log -p
![](https://img.haomeiwen.com/i13496666/96fba26812a807f5.png)
—— git标签
![](https://img.haomeiwen.com/i13496666/ae5bac5098121681.png)
假设最后一个版本非常重要,我们可以给他打个标签
命令:git tag -a(annotated) 标签名 -m "备注" [身份证定位标签]
![](https://img.haomeiwen.com/i13496666/a4846ba96196a561.png)
命令:git tag --列出所有标签
标签是默认加在最近的后悔药上,如果我们想在历史的节点上打上标签,我们可以
![](https://img.haomeiwen.com/i13496666/0509810eb6a98407.png)
![](https://img.haomeiwen.com/i13496666/0f75e3514b8a2b07.png)
命令:git show 标签名 --查看某个标签的详细信息
![](https://img.haomeiwen.com/i13496666/40e0e71e9e48c319.png)
Tagger:是谁加的Tagger,date:是什么时候修改的
加了tag也有好处,相当于给某次提交命名了
![](https://img.haomeiwen.com/i13496666/894409646ea1124b.png)
HEAD所在位置说明我们最近提交在这里,如果我们想回到two标签的版本,我们可以
命令:git checkout 标签名 --回溯至标签所在的提交
![](https://img.haomeiwen.com/i13496666/26633c015d9f5d30.png)
网友评论