Git 简介
Git 是目前最先进的分布式版本控制系统。
那么,什么是版本控制系统呢?
形象地讲,版本控制就是按照纵向或横向的维度记录当前工程下的变更并进行管理,方便用户可以穿梭于当前工程的不同的变更状态,纵向的维度就是时间的维度,而横向的维度就是分支的维度。在软件开发中经常利用分支的功能将稳定和变动隔离开来,已经稳定的代码是默认的主分支,而新的特性,功能等则是其他分支。
如何使用 Git 的分支特性并无标准答案,但却有大家总结或约定俗称的使用方式,这里推荐简要了解一下git分支管理策略。
那么什么是分布式版本控制系统?版本控制系统并非只有 Git 一种,再此之前还有 SVN 和 CSV,相对的,这两者是集中式版本控制系统。分布式版本控制系统会在每台部署了版本控制的电脑上存储完整的版本库,而集中式版本控制系统则只会在一台主机上保存版本库。因此分布式版本库不仅不需要联网就可以使用,而且更安全,更方便。
Git 基本概念
想要用好 Git,首先要了解 Git 的几个基本概念。
Workspace:工作区,平时存放工程代码的地方,也就是工程文件夹。
Index / Stage:暂存区,用于临时存放你的改动,实际上这是一个文件,里面保存即将提交的文件的信息,一般存放在隐藏目录.git 目录下的 index 文件中。
Repository:仓库区(或版本库),本地仓库,当前工程路径下的隐藏目录 .git。
Remote:远端仓库。
Git 工作流程
以上图为例:
1、从远端仓库 clone 一个仓库到本地,或在本地创建并初始化一个仓库
2、在工作区中对文件进行添加、编辑、修改、删除
3、将需要进行版本管理的文件从工作区中 add 后放入暂存区
4、确认需要保存的更改从暂存区中 commit 至版本库
5、最后如果需要将本地版本库同步就将版本库 push 至远端工作区
1
RT-Thread Studio 中 Git 信息的配置
按如下图配置 RT-Thread Studio 中的 Git 插件
打开窗口 -》 首选项 -》 配置
在图中 user 下填入代码托管平台的 email 和 name,如需配置网络代理,可配置 http 代理信息。
2
RT-Thread Studio 中 Git 视图面板介绍
按下图打开 git 视图
上图所示, 从左至右的按钮的功能分别为,
导入外部已存在的本地版本库
从远端仓库 clone 一个版本库至本地
创建一个新的版本库并添加至当前视图
刷新
与工作树所选内容连接
显示平行分支布局
显示最新分支的提交
左边区域为版本库的文件树
右边区域为git相关操作的面板,通过打开不同的选项卡可以进行如diff,commit等基本操作
3
Studio创建本地仓库
切换至Git 视图后按如下步骤新建本地仓库
也可以直接从菜单栏新建本地仓库
注:新建本地仓库后需要新建工程并保存至仓库路径,然后添加至暂存区才可以跟踪工程文件的变更
4
RT-Thread studio 导入外部仓库
切换至 Git 视图后按如下步骤添加外部已存在仓库至 RT-Thread Studio
5
RT-Thread Studio 克隆远程仓库
按如下图所示步骤克隆远程仓库至 RT-Thread Studio
克隆后导入工程(注:只有 eclipse 工程才可以导入成功)
注:从远程仓库克隆至本地后需要导入 RT-Thread Studio 工程,才可以在项目资源管理器中显示工程内容。
6
Git 在 RT-Thread Studio 中的基本操作
拉取远程仓库代码
添加文件到暂存区
暂存区内容添加到仓库
推送本地仓库至远程仓库
文件历史版本比较
按如图所示打开文件变更比较
RT-Thread Studio 工程与.gitignore
.gitignore用来描述不被git添加到版本管理中的文件,RT-Thread Studio的工程中大概有如下几类文件可以不被包括到版本管理中:
1、工程编译过程中产生的文件,如.elf、.bin、.hex、.map、.o,Debug 目录下以及 build 目录下的文件等
2、与当前工程不相关的工程配置文件,如.vscode目录下的文件,.uvguix*等
编辑:jq
-
Studio
+关注
关注
2文章
194浏览量
28878 -
插件
+关注
关注
0文章
336浏览量
22514 -
Git
+关注
关注
0文章
201浏览量
15835 -
RT-Thread
+关注
关注
31文章
1308浏览量
40492
原文标题:【使用技巧】如何在RT-Thread Studio上使用GIT进行工程管理
文章出处:【微信号:LinuxDev,微信公众号:Linux阅码场】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
如何将RT-Thread移植到NXP MCUXPressoIDE上
![如何将<b class='flag-5'>RT-Thread</b>移植到NXP MCUXPressoIDE<b class='flag-5'>上</b>](https://file1.elecfans.com/web3/M00/08/12/wKgZPGetWzWAPmQsAAAT9RkoMiQ238.png)
RT-Thread上CAN实践
![<b class='flag-5'>RT-Thread</b><b class='flag-5'>上</b>CAN实践](https://file1.elecfans.com/web2/M00/C4/8A/wKgZomX0EhWACv8DAAAUet8ikhs451.png)
为什么在rt-thread studio创建不了gd32的项目?
RT-Thread Studio构建和重新构建的不同,一般我们编译工程时用哪个?
【ch32v307_RTT】1、使用RT-Thread studio新建工程
6月6日杭州站RT-Thread线下workshop,探索RT-Thread混合部署新模式!
![6月6日杭州站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!](https://file1.elecfans.com/web2/M00/C4/8A/wKgZomX0EhWACv8DAAAUet8ikhs451.png)
RT-Thread混合部署Workshop北京站来啦!
![<b class='flag-5'>RT-Thread</b>混合部署Workshop北京站来啦!](https://file1.elecfans.com/web2/M00/C4/8A/wKgZomX0EhWACv8DAAAUet8ikhs451.png)
4月25日北京站RT-Thread线下workshop,探索RT-Thread混合部署新模式
![4月25日北京站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式](https://file1.elecfans.com/web2/M00/C4/8A/wKgZomX0EhWACv8DAAAUet8ikhs451.png)
4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!
![4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!](https://file1.elecfans.com/web2/M00/C6/D0/wKgaomYDlJyAKUBmAAAgR-TqYwc187.png)
4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!
![4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!](https://file1.elecfans.com/web2/M00/C4/8A/wKgZomX0EhWACv8DAAAUet8ikhs451.png)
评论