查看原文
其他

Git实用教程(三) | Git本地库操作(仓库初始化、提交修改)

mculover666 Mculover666 2021-01-31

Git实用教程专栏回顾


1.获取Git仓库

方法1. 在现有目录下初始化一个新的本地仓库

  • 在Git Bash中进入工作目录或者直接在工作目录右击,选择Git Bash Here打开Git命令行

  • 使用命令初始化仓库:


git init

  • 本地仓库初始化成功后,Git会在当前目录新建一个.git的隐藏文件夹,该文件夹中包含了初始化的Git仓库中所有的必须文件,具体在后续详细讲解:

方法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 statusgit 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 <文件名>

好啦!今天的Git讲解就到这儿,来个思维导图回顾一下吧~

思维导图使用『幕布』绘制


推荐阅读:

更多精彩文章及资源,欢迎关注我的微信公众号:『mculover666』。






    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存