学生时期,相信大家都有下面的经历,写毕业论文的时候,每次修改之前,都会先把当前最新的版本复制一份,然后再重新命名一个标题,但是,之前的旧版本又不会删掉,为了保险起见,感觉万一新的文档没改好还能有个旧的版本可以用。

 


于是,就有了下面的一幕:

 

 

大家别笑,这都是真实发生的案例,更有甚者,自己笔记本拷贝毕业论文到 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 的功能非常强大,我们这里只是介绍了其中一部分,剩下的下次再跟大家唠嗑。