作者:晓宇,整理:晓宇
微信公众号:芯片之家(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/,大家各自注册号账号。
点击管理,把我们刚刚复制的那个链接放进URL框中,点击保存。这个链接是我们项目的远端地址,也是我们将本地文件推送的地址,然后确定推送。
如果推送失败,需要先拉取一下服务器文件更新一下本地仓库,然后再推送即可。
主页动态框这里,马上就更新了,提示,某某某在什么时间段推送了什么文件到哪个分支,在多人服务同一个项目的时候特别有用。
我们再看看项目页面,可以看到,我们的整个工程文件都更新到服务器了。
过了几天,我们更新了V1.1.0版本,在主函数中增加了一个SENSOR_Task的任务,部分改动如下:
1、增加了注释;2、增加了宏定义以及任务句柄定义;3、主函数中新增了一个任务。
我们保存编译之后,重新提交,方法还是按照上面的,提交之前,我们看到文件夹的图标由之前绿色的对号变成了红色的感叹号,绿色代表文件目前都是最新的,红色代表里面又改动过了,还没提交。
我们在可以看到本次提交的变更列表中,主要改动的就是main.c文件,我们双击一下main.c这一行。
黄色背景部分直接就显示出了新旧两个main.c之间改动过的地方,这一功能是不是特有用,当我们想找回以前版本到底改动了哪些的时候,直接在对话框中选中相应的版本,然后在变更列表中我们就可以很清晰的看出被改动过的每一行。
然后我们像之前一样点击提交,提交之后,可以再网页动态看到本次提交的信息,然后在项目统计这里,我们可以看到完整的项目提交历史。
在这个界面,我们可以非常清晰的看到各个版本之间的变更信息,提交的作者以及日期,对于我们掌控整个项目的生命周期,能起到非常重要的作用。
我们想导出哪个历史版本,直接在对应版本右键导出即可。
啰嗦了一大堆,我们上面说的,说白了就是一个软件,这个软件可以帮助我们以可视化的方式管理我们的程序版本,方便我们追溯回顾历史更改,同时可以提交到服务器,便于备份文件,同时,也方便我们在不同的地点,环境修改代码,改完之后提交到服务器,这样,这服务器永远保留最新的版本,不同的终端也可以看到修改的问题点,大大的方便了我们的项目管理。本次先带大家简单入门,大家也可以自己摸索,TortoiseGit的功能非常强大,我们这里只是介绍了其中一部分,剩下的下次再跟大家唠嗑。谢谢大家阅读到这里,希望大家在学习的同时可以enjoy!喜欢请 点赞并转发 支持我们,您的转发就是我们继续创作的最佳动力,谢谢大家!请戳右下角,给我一点在看!