Git实用教程(三) | 您所在的位置:网站首页 › 暂存待办提交 › Git实用教程(三) |
Git实用教程专栏回顾 Git实用教程(一) | 为什么需要版本控制?(以嵌入式项目开发为例)Git实用教程(二) | Git简介及安装详解1.获取Git仓库 方法1. 在现有目录下初始化一个新的本地仓库在Git Bash中进入工作目录或者直接在工作目录右击,选择Git Bash Here打开Git命令行;使用命令初始化仓库: git init![]() ![]() ![]() 克隆远程仓库的命令格式是: git clone如果想在克隆的时候自定义仓库的名字,格式如下: git clone 2.提交更新到仓库(重点)在当前工作目录下,Git对一个文件的状态有两种: 已跟踪:在上一次提交的快照中有记录,已被纳入版本管理(获取仓库时,工作目录下所有的文件都是已跟踪文件);未跟踪:除已跟踪文件之外的所有文件都属于未跟踪文件。![]() 查看工作目录下所有文件的状态命令: git status![]() 当文件数量多时可以使用-s参数输出简短信息: git status -s格式 说明 左边的M 文件被修改,并且已放入暂存区 右边的M 文件被修改,未放入暂存区 MM 在工作区被修改后提交到暂存区,在工作区又被修改了 A 新添加到暂存区的文件 ?? 新添加的未跟踪的文件 2.2.跟踪新文件git add 文件名支持通配符`(比如`.c表示工作区所有c文件);如果是目录,则递归跟踪该目录下所有文件;使用-A参数表示跟踪所有文件: git add -A![]() 使用vim打开test.c并编辑如下代码: ![]() ![]() 已跟踪文件修改后查看状态,会提示Changes not staged for commit,这表明文件修改后没有保存到暂存区,使用如下命令将修改保存到暂存区: git add![]() 使用-A参数表示暂存所有已修改文件: git add -A![]() 在工作区工作的时候,我们想要知道: 当前做的哪些更新没有暂存?有哪些更新已经暂存起来准备下次提交?使用git status命令只能表明文件,要查看具体内容使用该命令: git diff该命令比较工作目录中和暂存区文件的差异,即:已经修改但还未暂存的内容,最后通过文件补丁的格式表明具体哪些行发生了变化。 如图,在test.c文件中添加一行代码: ![]() 然后分别使用git status和git diff查看: ![]() 如果需要查看已经暂存起来的修改使用如下命令: git diff --staged![]() 注:提交操作前请确保已设置用户名和邮箱。 使用如下命令将暂存区的内容提交到仓库: git commit该命令只会将暂存区的内容提交到仓库,所以在提交之前需要使用git status查看,确认所有改变已经暂存。 该命令执行后会自动调用默认编辑器vim来编辑提交信息,之后保存即可成功提交。 如果提交信息比较简单,可以直接一行搞定: git commit -m ""![]() ![]() 每次提交都是对该项目的一个快照,在以后的任何时候都可以回退到该次状态。 2.7.跳过暂存区域直接提交更新先将工作区的内容提交到暂存区,然后将暂存区的内容提交到仓库,这样的过程未免过于繁琐,使用如下命令可以跳过暂存区,直接将工作区修改的文件(未追踪的文件不能直接提交)添加到仓库: git commit -a -m ""![]() ![]() 一般情况下,我们总会有些文件不需要纳入Git 的管理,比如: 编译生成的中间文件、临时文件、可执行文件等等;日志文件……解决方法:在工作目录下创建一个名为.gitignore的文件来列出忽略文件的模式。 文件.gitignore的格式规范如下: 所有空行或者以#开头的行会被Git忽略;可以使用标准的glob模式匹配;匹配模式可以以(/)开头防止递归;匹配模式可以以(/)结尾指定目录;要忽略指定模式以外的文件或目录,可以在模式前加(!)表示取反;在这里我们编辑一个.gitignore文件作为示例: ![]() 然后编译产生中间文件和可执行文件: ![]() 查看Git对当前文件的状态: ![]() 要从Git的暂存区和仓库中移除一个文件,有两种情况: 从暂存区删除,并且从工作目录删除源文件:git rm 从暂存区删除,保留工作区的源文件:git rm --cached![]() 好啦!今天的Git讲解就到这儿,来个思维导图回顾一下吧~ 思维导图使用『幕布』绘制 ![]() |
CopyRight 2018-2019 实验室设备网 版权所有 |