打印
[ARM入门]

软件开发为什么需要版本管理?

[复制链接]
683|4
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
沙发
问天少年|  楼主 | 2022-6-1 10:02 | 只看该作者
1. 为什么需要版本控制在我们每个人独立开发项目的时候,都会不知不觉的用到版本控制,只是我们并不知道“版本控制”这个名词,没有过多的在意~比如我要做一个数字电压表的项目,该项目要实现的功能是采集0-5V电压并显示在OLED屏幕上,其芯片选型如下:
  • 主控芯片:STC89C52RC;
  • AD芯片:ADC0832;
  • 显示模块:0.96'OLED(IIC);
首先使用公板(开发板)开发软件程序,大致开发流程如下:
  • 编写STC89C52RC的串口驱动程序,实现串口发送功能,用于后期调试;
  • 编写ADC0832的驱动程序,实现采集电压值并通过串口发送功能
  • 编写OLED的驱动程序,实现电压值实时显示功能
所以项目文件夹安排如下:
不经意间,我们手动实现了该项目的版本控制,每个文件夹就是一个版本,这样做的好处是什么呢?

  • 提高代码重用性
    比如其中的01-bsp_uart_tx文件夹,实现了串口发送的独立功能,当下次项目中需要时,可以直接拷贝过去而无需重写;
  • 方便版本回退(重点)
    当编写第三个功能03-adc0832+uart+oled的时候,因为思路不清晰导致代码出错,这个时候如果将新添加的代码都找到删除,工作量非常大,而且效率极低,有了版本控制,我们可以直接在02-adc0832+uart的基础上重新编写;
在公板上验证程序无误后,便可以转入硬件开发:设计原理图,绘制PCB,生产焊接调试等工作,同样,在绘制原理图和PCB时,我们依然可以使用版本控制,在后续会有专门的一篇文章简述电路图的版本控制,此处不作赘述。




使用特权

评论回复
板凳
问天少年|  楼主 | 2022-6-1 10:02 | 只看该作者
2.为什么需要版本控制工具在上一节中我们通过多个文件夹的方式手动实现了版本控制,但是该方式也有一个非常大的缺点:
  • 迭代建立文件夹,重复内容多
  • 版本迭代时修改的内容无法查看
为了解决这一问题,诞生的主流的版本控制软件:
  • 集中式版本控制工具:SVN
  • 分布式版本控制工具:Git
使用版本控制软件可以解决这一大问题并且带来许多其他的优点,诸如:
  • 保存了数据当前状态以及之前每一个提交的历史状态,可以回退到任意一个版本节点
  • 在保存每一个版本的文件信息时不重复保存数据,节约存储空间,提高运行效率
  • 可以清楚到看到不同版本间修改的内容
  • 可以多人协作,团队开发




使用特权

评论回复
地板
问天少年|  楼主 | 2022-6-1 10:04 | 只看该作者
3. 版本控制软件的多人协作优势
继续拿上面的项目为例来说明版本控制软件的多人协作优势~
假设:
  • A同学负责adc0832的驱动实现,在main.c中编写测试函数进行测试;
  • B同学负责OLED的驱动实现,在main.中编写测试函数进行测试;

A完成测试后将main.c文件提交到公共服务器上,当B提交main.c后,公有服务器上A提交的main.c被B提交的文件所覆盖
使用版本控制软件即可很好的解决这一问题,并且具有以下优势:
  • 协同修改
  • 多个人可以修改服务器上的同一个文件,互不影响;
  • 权限管理
  • 对团队中参与开发的人员进行权限控制;
  • 对团队外参与开发的人员贡献的代码进行审核(Git独有);
  • 历史记录
  • 查看修改人、修改时间、修改内容、修改日志;



使用特权

评论回复
5
呐咯密密| | 2022-6-1 12:41 | 只看该作者
版本管理对我来说最重要的就是方便回退,有时候推进代码时会遇到问题,找不到问题的根源就需要将带啊回退,一点点排除。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

57

主题

405

帖子

1

粉丝