Git实用教程(三) 您所在的位置:网站首页 暂存待办提交 Git实用教程(三)

Git实用教程(三)

2023-10-21 11:22| 来源: 网络整理| 查看: 265

Git实用教程专栏回顾

Git实用教程(一) | 为什么需要版本控制?(以嵌入式项目开发为例)Git实用教程(二) | Git简介及安装详解1.获取Git仓库 方法1. 在现有目录下初始化一个新的本地仓库在Git Bash中进入工作目录或者直接在工作目录右击,选择Git Bash Here打开Git命令行;使用命令初始化仓库: git init 本地仓库初始化成功后,Git会在当前目录新建一个.git的隐藏文件夹,该文件夹中包含了初始化的Git仓库中所有的必须文件,具体在后续详细讲解:方法2.克隆(拉取)现有的仓库到本地

克隆远程仓库的命令格式是:

git clone

如果想在克隆的时候自定义仓库的名字,格式如下:

git clone 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 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

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

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



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有