## 2.2 记录每次更新到仓库
Git 中文件的变化周期如下:

### 2.2.1 检查当前文件状态
要查看哪些文件处于什么状态,可以通过`status`指令查看文件状态,在`.gitconfig`中可以设置高亮。
```
$ git status
```
通过可选参数项`-s`查看状态简介:
```
$ git status -s
```
* `??`:表示新添加的未跟踪文件
* `A`:表示新添加到暂存区的文件
* `_M`:表示修改过的文件并且已经放入暂存区
* `M_`:表示修改过的文件并且没有放入暂存区
### 2.2.2 跟踪新文件 & 暂存已修改文件
`git add`命令使用文件或目录的路径作为参数;如果参数是目录的路径,该命令将递归地跟踪该目录下的所有文件:
```
$ git add [file]
```
其中 `file` 参数是支持正则表达式的,并且命令支持交互式暂存:
```
$ git add -i
$ git add --interactive
```
### 2.2.3 忽略跟踪文件配置
在仓库中忽略某些文件的跟踪,需要创建一个名为`.gitignore`的文件,列出需要忽略的文件
* 所有空行或者以注释符号 # 开头的行都会被 Git 忽略
* 可以使用标准的 glob 模式匹配(glob 模式是指 shell 所使用的简化了的正则表达式)
* 匹配模式最后跟反斜杠(/)说明要忽略的是目录
* 要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反
Tips:Github 有一个十分详细的针对数十种项目及语言的 `.gitignore` 文件列表,[链接](https://github.com/github/gitignore)。
### 2.2.4 查看已暂存和未暂存的修改
`status` 命令通过在相应栏下列出文件名的方式来展示文件的状态,而想要具体了解文件修改情况,可以使用 `diff` 命令将修改通过文件补丁的格式显示具体哪些行发生了变化。
显示工作区域文件(未暂存的文件)的修改:
```
$ git diff
```
显示在暂存区域文件的修改:
```
$ git diff --cached
$ git diff --staged
```
显示两个版本的差异:
```
$ git diff [SHA-1] [SHA-2]
```
### 2.2.5 提交更新
使用`commit` 指令可以将操作提交至仓库,并会启用编辑器获取本次的提交说明:
```
$ git commit
```
可选参数项:
* `-m`: 直接附带提交说明
```
$ git commit -m"info"
```
* `-a`: 跳过暂存区域提交操作至仓库
```
$ git commit -a
```
* `--amend`: 本次提交覆盖最后一次提交
```
$ git commit --amend
```
### 2.2.6 移除文件
要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除,然后提交,通过 `rm` 命令可以将文件从已跟踪文件清单和工作目录中一并移除。
```
$ git rm [file]
```
如果移除之前文件被修改过,并且已经放入暂存区,则需要使用强制删除选项 `-f` :
```
$ git rm -f [file]
```
### 2.2.7 移动文件
在 Git 中重命名文件可以通过 `mv` 命令:
```
$ git mv [file_from] [file_to]
```
该命令实际上相当于运行了下面三条命令:
```
$ mv [file_from] [file_to]
$ git rm [file_from]
$ git add [file_to]
```
所以,即便是分开执行这三条命令,Git 也会识别这是一次改名操作。
- 介绍
- 第一章 起步
- 1.1 关于版本控制
- 1.2 Git 简史
- 1.3 Git 基础
- 1.4 命令行
- 1.5 安装 Git
- 1.6 初次运行 Git 前的配置
- 1.7 获得帮助
- 第二章 基础
- 2.1 获取仓库
- 2.2 记录每次更新到仓库
- 2.3 查看提交历史
- 2.4 撤销操作
- 2.5 远程仓库的使用
- 2.6 打标签
- 2.7 Git 别名
- 第三章 分支
- 3.1 分支简介
- 3.2 分支的新建与合并
- 3.3 分支管理
- 3.4 分支开发工作流
- 3.5 远程分支
- 3.6 变基
- 第四章 服务器上的 Git
- 4.1 协议
- 4.2 在服务器上搭建 Git
- 4.3 生成 SSH 公钥
- 4.4 配置服务器
- 4.5 Git 守护进程
- 4.6 Smart HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 第三方托管的选择
- 第五章 分布式 Git
- 5.1 分布式工作流程
- 5.2 向一个项目贡献
- 5.3 维护项目
- 第六章 GitHub
- 6.1 账户的创建和配置
- 6.2 对项目做出贡献
- 6.3 维护项目
- 6.4 管理组织
- 6.5 脚本 GitHub
- 第七章 Git 工具
- 7.1 选择修订版本
- 7.2 交互式暂存
- 7.3 储藏与清理
- 7.4 签署工作
- 7.5 搜索
- 7.6 重写历史
- 7.7 重置揭密
- 7.8 高级合并
- 7.9 Rerere
- 7.10 使用Git调试
- 7.11 子模板
- 7.12 打包
- 7.13 替换
- 7.14 凭证存储
- 第八章 自定义 Git
- 8.1 配置 Git
- 8.2 Git 属性
- 8.3 Git 钩子
- 8.4 使用强制策略的一个例子
- 第九章 Git 与其他系统
- 9.1 作为客户端的 Git
- 9.2 迁移到 Git
- 第十章 Git 内部原理
- 10.1 底层命令和高层命令
- 10.2 Git 对象
- 10.3 Git 引用
- 10.4 包文件
- 10.5 引用规格
- 10.6 传输协议
- 10.7 维护与数据恢复
- 10.8 环境变量
