【Git & Github】(三)Git命令行操作 —— 本地库操作(获取Git仓库、提交更新到仓库)
1.1. 在现有目录下初始化仓库
- 在Git Bash中进入工作目录或者直接在工作目录右击,选择Git Bash Here打开Git命令行;
- 使用命令初始化仓库:
git init
- 本地仓库初始化成功后,Git会在当前目录新建一个.git的隐藏文件夹,该文件夹中包含了初始化的Git仓库中所有的必须文件,具体在后续详细讲解:
1.2.克隆现有的仓库
克隆远程仓库的命令格式是:
git clone <url>
如果想在克隆的时候自定义仓库的名字,格式如下:
git clone <url> <new repository name>2.提交更新到仓库(重点)
在当前工作目录下,Git对一个文件的状态有两种:
- 已跟踪:在上一次提交的快照中有记录,已被纳入版本管理(获取仓库时,工作目录下所有的文件都是已跟踪文件);
- 未跟踪:除已跟踪文件之外的所有文件都属于未跟踪文件。
2.1.查看文件当前状态
查看工作目录下所有文件的状态命令:
git status
当文件数量多时可以使用-s参数输出简短信息:
git status -s
| 格式 | 说明 |
|---|---|
| 左边的M | 文件被修改,并且已放入暂存区 |
| 右边的M | 文件被修改,未放入暂存区 |
| MM | 在工作区被修改后提交到暂存区,在工作区又被修改了 |
| A | 新添加到暂存区的文件 |
| ?? | 新添加的未跟踪的文件 |
2.2.跟踪新文件
git add <文件名或者目录>
- 文件名支持通配符*(比如*.c表示工作区所有c文件);
- 如果是目录,则递归跟踪该目录下所有文件;
使用-A参数表示跟踪所有文件:
git add -A
2.3.修改当前文件
使用vim打开test.c并编辑如下代码:
#include <stdio.h>
int main(void)
{
printf("Hello World.\n");
return 0;
}
2.4.暂存已修改文件
已跟踪文件修改后查看状态,会提示Changes not staged for commit,这表明文件修改后没有保存到暂存区,使用如下命令将修改保存到暂存区:
git add <文件名>
使用-A参数表示暂存所有已修改文件:
git add -A
2.5.查看未暂存和已暂存的修改
在工作区工作的时候,我们想要知道:
- 当前做的哪些更新没有暂存?
- 有哪些更新已经暂存起来准备下次提交?
使用git status命令只能表明文件,要查看具体内容使用该命令:
git diff
该命令比较工作目录中和暂存区文件的差异,即:已经修改但还未暂存的内容,最后通过文件补丁的格式表明具体哪些行发生了变化。
如图,在test.c文件中添加一行代码:
然后分别使用git status和git diff查看:
如果需要查看已经暂存起来的修改使用如下命令:
git diff --staged
2.6.提交更新
注:提交操作前请确保已设置用户名和邮箱。
使用如下命令将暂存区的内容提交到仓库:
git commit
该命令只会将暂存区的内容提交到仓库,所以在提交之前需要使用git status查看,确认所有改变已经暂存。
该命令执行后会自动调用默认编辑器vim来编辑提交信息,之后保存即可成功提交。
如果提交信息比较简单,可以直接一行搞定:
git commit -m "<提交信息>"
每次提交都是对该项目的一个快照,在以后的任何时候都可以回退到该次状态。
2.7.跳过暂存区域直接提交更新
先将工作区的内容提交到暂存区,然后将暂存区的内容提交到仓库,这样的过程未免过于繁琐,使用如下命令可以跳过暂存区,直接将工作区修改的文件(未追踪的文件不能直接提交)添加到仓库:
git commit -a -m "<提交信息>"
2.8.忽略文件
一般情况下,我们总会有些文件不需要纳入Git 的管理,比如:
- 编译生成的中间文件、临时文件、可执行文件等等;
- 日志文件
- ……
解决方法:在工作目录下创建一个名为.gitignore的文件来列出忽略文件的模式。
文件.gitignore的格式规范如下:
- 所有空行或者以#开头的行会被Git忽略;
- 可以使用标准的glob模式匹配;
- 匹配模式可以以(/)开头防止递归;
- 匹配模式可以以(/)结尾指定目录;
- 要忽略指定模式以外的文件或目录,可以在模式前加(!)表示取反;
在这里我们编辑一个.gitignore文件作为示例:
然后编译产生中间文件和可执行文件:
查看Git对当前文件的状态:
2.9.移除文件
要从Git的暂存区和仓库中移除一个文件,有两种情况:
- 从暂存区删除,并且从工作目录删除源文件:
git rm <文件名>
- 从暂存区删除,保留工作区的源文件:
git rm --cached <文件名>




















