作者:晓宇,整理:晓宇
微信公众号:芯片之家(ID:chiphome-dy)
学生时期,相信大家都有下面的经历,写毕业论文的时候,每次修改之前,都会先把当前最新的版本复制一份,然后再重新命名一个标题,但是,之前的旧版本又不会删掉,为了保险起见,感觉万一新的文档没改好还能有个旧的版本可以用。
于是,就有了下面的一幕:
大家别笑,这都是真实发生的案例,更有甚者,自己笔记本拷贝毕业论文到U盘,在其它电脑修改了,又忘记更新回自己电脑,或者,时间长了,想找到之前文档中的一些文字,但是又忘记在那个版本来。
是不是非常苦恼,你可能觉得,那我找回之前的版本一个个查看不就可以了,又没删,但是你这才几个文件,如果文件数量翻几倍呢?
那么,有没有什么软件可以帮助我们对文件进行版本控制呢?今天,晓宇姐姐教大家用Git来进行版本控制。
听到Git,一些单片机或者是软件开发的初学者又打算停止看下去了,好麻烦啊,又得记一堆命令,每次改完我也懒得命令提交,我还是通过日期来记录好了,于是又出现下面一幕:
项目完成初期,还大致记得每个版本改了什么,1个月后,需要某个旧版本的信息,或者新的版本出了什么问题,需要追溯查找改动的代码部分,这时候,麻烦就来了,工程师喃喃自语道 "我好像记得改了这个地方,但是不知道是不是只有这个地方改动来",然后,很苦逼的一个文件一个文件的去对比。
看到上面的这一幕,我们肯定不想重蹈上面工程师的覆辙,但是即使用文件记得再详细,当在不同电脑,或者是不同工程师开发同一个项目的时候,几乎不可能不出错的记录,而且这样记录,很累。
上面说的一大堆,所谓欲扬先抑,就是为了引出我们今天的主角,一个软件版本控制神器--TortoiseGit。
TortoiseGit,简称tgit,中文名海龟Git,是一个GIT版本控制系统的客户端。
我们需要先下载几个软件,并依次安装好:
1、Git-2.28.0-64-bit,大家根据自己的系统下载(https://git-scm.com/download/win)
2、TortoiseGit(https://tortoisegit.org/download/)
3、TortoiseGit Language Packs,汉化包,下载链接同上。
我们在E盘项目文件下创建一个文件夹,用来存储以太网网关项目的资料,并右键执行如下操作,在此文件夹下面创建一个版本库:
可以看到,在文件夹下多了一个.git的隐藏文件夹,千万不要删掉,这个就是我们的版本记录文件。
进行正式操作之前,我们先简单配置一下软件:
最后一幅图,配置用户信息,做为用户操作git的个人标识,我们填写个人名称跟邮箱,然后编辑一下全局变量,加入以下配置,用于记住密码。,之后保存退出即可。
[credential]
helper = store
我们把我们第一版本的工程文件放入software文件夹下,然后打开工程,这就是我们的V1.0.0版本的原始程序了。
V1.0.0版本的程序写好之后,我们需要先提交一次,如下操作:
然后会弹出一个对话框,注意,这个是重点:
第一个红框中,需要填写版本日志信息,需要说明这个版本所更新的内容;第二个红框中,为提交者的的名字以及提交的日期,这个主要在多人协同中比较有用;第三个红框勾选全部,然后会把本次更新所涉及到的文件全部选中,最后选择提交。
看到下图红框中的成功,表示本次推送成功,这里,仅仅是把更新推送到本地Git仓库,文件都还在本地。
我们的代码版本,不仅可以存在本地仓库存储,还可以推送到云端服务器进行保存,我们可以搭建本地的Git服务器,也可以使用现成的Git服务器,这里推荐其中一个平台--码云。
对的,你没听错,是码云,网址:https://gitee.com/,大家各自注册号账号。
然后,按照下图建立一个私有仓库
然后复制这个地址
右键工程项目,点击Git推送
点击管理,把我们刚刚复制的那个链接放进URL框中,点击保存。这个链接是我们项目的远端地址,也是我们将本地文件推送的地址,然后确定推送。
如果推送失败,需要先拉取一下服务器文件更新一下本地仓库,然后再推送即可。
推送成功之后,我们看看网页端有什么变化。
主页动态框这里,马上就更新了,提示,某某某在什么时间段推送了什么文件到哪个分支,在多人服务同一个项目的时候特别有用。
我们再看看项目页面,可以看到,我们的整个工程文件都更新到服务器了。
过了几天,我们更新了V1.1.0版本,在主函数中增加了一个SENSOR_Task的任务,部分改动如下:
1、增加了注释;2、增加了宏定义以及任务句柄定义;3、主函数中新增了一个任务。
我们保存编译之后,重新提交,方法还是按照上面的,提交之前,我们看到文件夹的图标由之前绿色的对号变成了红色的感叹号,绿色代表文件目前都是最新的,红色代表里面又改动过了,还没提交。
我们在可以看到本次提交的变更列表中,主要改动的就是main.c文件,我们双击一下main.c这一行。
黄色背景部分直接就显示出了新旧两个main.c之间改动过的地方,这一功能是不是特有用,当我们想找回以前版本到底改动了哪些的时候,直接在对话框中选中相应的版本,然后在变更列表中我们就可以很清晰的看出被改动过的每一行。
然后我们像之前一样点击提交,提交之后,可以再网页动态看到本次提交的信息,然后在项目统计这里,我们可以看到完整的项目提交历史。
在本地文件夹,我们也可以查看版本记录,方法如下:
在这个界面,我们可以非常清晰的看到各个版本之间的变更信息,提交的作者以及日期,对于我们掌控整个项目的生命周期,能起到非常重要的作用。
当我们更新了N次之后,界面就是这样子的
我们想导出哪个历史版本,直接在对应版本右键导出即可。
啰嗦了一大堆,我们上面说的,说白了就是一个软件,这个软件可以帮助我们以可视化的方式管理我们的程序版本,方便我们追溯回顾历史更改,同时可以提交到服务器,便于备份文件,同时,也方便我们在不同的地点,环境修改代码,改完之后提交到服务器,这样,这服务器永远保留最新的版本,不同的终端也可以看到修改的问题点,大大的方便了我们的项目管理。
本次先带大家简单入门,大家也可以自己摸索,TortoiseGit的功能非常强大,我们这里只是介绍了其中一部分,剩下的下次再跟大家唠嗑。
1.芯师爷|2020硬核中国芯 重磅启动!
2.【直播福利+预告】第三期“嵌入式与物联网开发技术”线上分享即将开始啦~
3.使用ZYNQ实现复杂嵌入式系统,真的好用!
4.工业互联网:嵌入式系统的机遇和挑战
5.余承东签发内部文件:华为要造屏幕芯片!
6.RTOS是如何实现多任务的?
免责声明:本文系网络转载,版权归原作者所有。如涉及作品版权问题,请与我们联系,我们将根据您提供的版权证明材料确认版权并支付稿酬或者删除内容。