前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Git实用教程(三) | Git本地库操作(仓库初始化、提交修改)

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

作者头像
Mculover666
发布2020-07-16 10:54:14
1.8K0
发布2020-07-16 10:54:14
举报
文章被收录于专栏:TencentOS-tinyTencentOS-tiny

Git实用教程专栏回顾

  • Git实用教程(一) | 为什么需要版本控制?(以嵌入式项目开发为例)
  • Git实用教程(二) | Git简介及安装详解

1.获取Git仓库

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

  • 在Git Bash中进入工作目录或者直接在工作目录右击,选择Git Bash Here打开Git命令行
  • 使用命令初始化仓库:
代码语言:javascript
复制

git init

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

方法2.克隆(拉取)现有的仓库到本地

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

代码语言:javascript
复制
git clone <url>

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

代码语言:javascript
复制
git clone <url> <new repository name>

2.提交更新到仓库(重点)

在当前工作目录下,Git对一个文件的状态有两种:

  • 已跟踪:在上一次提交的快照中有记录,已被纳入版本管理(获取仓库时,工作目录下所有的文件都是已跟踪文件);
  • 未跟踪:除已跟踪文件之外的所有文件都属于未跟踪文件。

2.1.查看文件当前状态

查看工作目录下所有文件的状态命令:

代码语言:javascript
复制
git status

当文件数量多时可以使用-s参数输出简短信息:

代码语言:javascript
复制
git status -s

格式

说明

左边的M

文件被修改,并且已放入暂存区

右边的M

文件被修改,未放入暂存区

MM

在工作区被修改后提交到暂存区,在工作区又被修改了

A

新添加到暂存区的文件

??

新添加的未跟踪的文件

2.2.跟踪新文件

代码语言:javascript
复制
git add <文件名或者目录>

  • 文件名支持通配符`(比如`.c表示工作区所有c文件);
  • 如果是目录,则递归跟踪该目录下所有文件

使用-A参数表示跟踪所有文件:

代码语言:javascript
复制
git add -A

2.3.修改当前文件

使用vim打开test.c并编辑如下代码:

代码语言:javascript
复制
#include <stdio.h>

int main(void)
{
    printf("Hello World.\n");
    return 0;
}

2.4.暂存已修改文件

已跟踪文件修改后查看状态,会提示Changes not staged for commit,这表明文件修改后没有保存到暂存区,使用如下命令将修改保存到暂存区:

代码语言:javascript
复制
git add <文件名>

使用-A参数表示暂存所有已修改文件:

代码语言:javascript
复制
git add -A

2.5.查看未暂存和已暂存的修改

在工作区工作的时候,我们想要知道:

  • 当前做的哪些更新没有暂存?
  • 有哪些更新已经暂存起来准备下次提交?

使用git status命令只能表明文件,要查看具体内容使用该命令:

代码语言:javascript
复制
git diff

该命令比较工作目录中和暂存区文件的差异,即:已经修改但还未暂存的内容最后通过文件补丁的格式表明具体哪些行发生了变化

如图,在test.c文件中添加一行代码:

然后分别使用git statusgit diff查看:

如果需要查看已经暂存起来的修改使用如下命令:

代码语言:javascript
复制
git diff --staged

2.6.提交更新

注:提交操作前请确保已设置用户名和邮箱

使用如下命令将暂存区的内容提交到仓库:

代码语言:javascript
复制
git commit

该命令只会将暂存区的内容提交到仓库,所以在提交之前需要使用git status查看,确认所有改变已经暂存

该命令执行后会自动调用默认编辑器vim来编辑提交信息,之后保存即可成功提交。

如果提交信息比较简单,可以直接一行搞定:

代码语言:javascript
复制
git commit -m "<提交信息>"

每次提交都是对该项目的一个快照,在以后的任何时候都可以回退到该次状态。

2.7.跳过暂存区域直接提交更新

先将工作区的内容提交到暂存区,然后将暂存区的内容提交到仓库,这样的过程未免过于繁琐,使用如下命令可以跳过暂存区,直接将工作区修改的文件(未追踪的文件不能直接提交)添加到仓库:

代码语言:javascript
复制
git commit -a -m "<提交信息>"

2.8.忽略文件

一般情况下,我们总会有些文件不需要纳入Git 的管理,比如:

  • 编译生成的中间文件、临时文件、可执行文件等等;
  • 日志文件
  • ……

解决方法:在工作目录下创建一个名为.gitignore的文件来列出忽略文件的模式。

文件.gitignore的格式规范如下:

  • 所有空行或者以#开头的行会被Git忽略;
  • 可以使用标准的glob模式匹配;
  • 匹配模式可以以(/)开头防止递归;
  • 匹配模式可以以(/)结尾指定目录;
  • 要忽略指定模式以外的文件或目录,可以在模式前加(!)表示取反;

在这里我们编辑一个.gitignore文件作为示例:

然后编译产生中间文件和可执行文件:

查看Git对当前文件的状态:

2.9.移除文件

要从Git的暂存区和仓库中移除一个文件,有两种情况:

  • 从暂存区删除,并且从工作目录删除源文件:
代码语言:javascript
复制
git rm <文件名>
  • 从暂存区删除,保留工作区的源文件:
代码语言:javascript
复制
git rm --cached <文件名>

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

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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-10-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Mculover666 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.获取Git仓库
  • 方法1. 在现有目录下初始化一个新的本地仓库
  • 方法2.克隆(拉取)现有的仓库到本地
    • 2.提交更新到仓库(重点)
    • 2.1.查看文件当前状态
    • 2.2.跟踪新文件
    • 2.3.修改当前文件
    • 2.4.暂存已修改文件
    • 2.5.查看未暂存和已暂存的修改
    • 2.6.提交更新
    • 2.7.跳过暂存区域直接提交更新
    • 2.8.忽略文件
    • 2.9.移除文件
    相关产品与服务
    短信
    腾讯云短信(Short Message Service,SMS)可为广大企业级用户提供稳定可靠,安全合规的短信触达服务。用户可快速接入,调用 API / SDK 或者通过控制台即可发送,支持发送验证码、通知类短信和营销短信。国内验证短信秒级触达,99%到达率;国际/港澳台短信覆盖全球200+国家/地区,全球多服务站点,稳定可靠。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档