杨昕磊
软件工程(3)这门课可以算是我本科期间至今为止最虐的一门课了。但与此同时这门课给我带来的收获和其他课程相比,也不是一个量级的。下面我就在本课程中学习到的对大型软件工程的理解与一些自己想说的话两个方面作为我个人总结的内容。
一、大型软件工程
所谓大型软件工程,相比于普通的中小型应用来讲,是一个功能众多,内部逻辑复杂的工程项目。软件工程大作业便是一个大型软件工程。与其它科目的大作业不同的是,它不是一个可以通过“大学式敏捷开发”(通俗的说,就是几天爆肝)的方式完成的。通过一个学期的大作业实践,我发现想做好一个大型的软件工程,以下几个方面至关重要:
-
清晰的产品模型规划
在开始开发前,一定要想清楚,需要开发的这个项目到底是一个什么样的东西,它的功能应该包括什么,其中哪些是主逻辑部分功能,哪些是拓展功能,你做出来的软件需要让什么人去用。我们组在开发过程中在这个问题上吃了大亏。由于一开始在选题时候我们简单地想着做一个代码众包平台。并没有仔细地去考虑到底要做成什么样子的,核心功能逻辑是哪些,功能亮点有什么,这导致我们在项目进行中遇到了很多很多问题,甚至在中期检查后对整个项目的功能进行了一次很大的增删,这导致我们的项目结构变得混乱。由于功能大改,导致原有的项目框架也随之改变,之前很多代码直接变成了无效代码,开发成本增大,开发效率一下变低。因此我觉得一个好的大型项目一定要在开发前想清楚要做的产品到底是一个什么样的产品。可以不需要想清楚每一个细节,但是涉及软件核心的逻辑与功能必须想清楚,否则,后患无穷。
合适的技术选型
在开发项目前我们需要进行技术选型。比如前端用什么框架?后端用什么框架?数据库用啥?当时很多组其实并没有特别在意技术选型,都会选择自己熟悉的或者擅长的框架进行大作业的开发。但其实技术选型很重要。我们在项目开发过程中一开始选用的是Mysql关系型数据库,但是由于软件众包涉及多对多关系非常复杂,显然MongoDb会更加适合这种数据模式,效率也会更高。再者我们当时选择了一个轻量级的UI框架foundation,但是foundation对React的支持实在是,太......了。文档特别草率,社区氛围凉凉,想用啥啥没有,最后沦落到用了UI框架还要写一大堆CSS的窘境。因此在项目中期检查之后我们更换了UI框架,使用了Ant Design,一下子,整个世界都明亮了!清晰的文档,效果展示,样例代码,控件每一个参数作用。简直和foundation天差地别!不敢想象我们没有更换UI框架,我们最后的界面会有多丑。因此,在进行了清晰的模型规划之后,技术选型也应该给予重视,一个合适的技术选型,能让你的开发如虎添翼。严谨的开发流程
由于开发的是一个大型项目,就应该选择大型项目工程的开发模式,如瀑布模型开发,增量模型开发,快速原型模型开发等等。由于开发团队很小,而且成员间很熟悉,甚至可能是一个宿舍的几个人,因此就觉得几个人在一起还要抽特定时间集中开发,开迭代会议很“表面”。但是事实证明,如果没有每周一个或多个特定时间的集中开发,大概率发生的情况是在迭代检查前一晚上爆肝,甚至通宵。没有迭代会议会导致,对整个项目完成进度失去控制与规划。会陷入:“啊,这次迭代我们做了很多了!你看有........”但其实没做的更多,的情况之中。因此项目集中开发与项目会议至关重要。在项目开始前需要有一个比较粗略的规划,到什么时间点需要大概做到什么程度。在每一次迭代会议上需要给上一个阶段的工作作出总结,细致地确定下一个阶段的工作细节,任务分配,安排下一个迭代集中开发时间与每一次开发要完成的任务点,这样才能做到有条不紊。否则,夜很长,你懂的。(三天三夜!三更半夜!不会有停歇!)关注开发细节
写代码的人很多时候会觉得,我东西都给你了,文档什么的不重要~其实在做一个项目的时候文档什么的,很重要。文档是给用户看的,也是给开发团队看的。比如愿景文档(让开发团队知道自己产品需要哪些功能),原型设计文档(让前端开发者知道页面需要做成啥样),API文档 (前后端对接规范,可以让前后端开发分开进行,不会因为对方拖慢自己的进度),测试文档(确定测试方案,测试环境,测试工具,设计测试用例)。没有文档记录的开发是不完整并且混乱的,我们组一开始开发时不太关注这方面的东西,因此产生了各种问题。因此在大型项目开发过程中,文档至关重要,没有文档,就没有一个好的大型项目,开发过程也必定是痛苦而凌乱的。
二、一些想说的话
这门课是我遇到的最硬的课。其价值远远超越了5学分的意义。由于大作业开发需要组队,整个项目的开发都是由你选择的团队一起进行的。因此选择一个合适自己的团队至关重要。团队中每一个人都应该对项目有一个相同清晰的目标,大家一起朝一个方向努力。拒绝拖延症,否则睡觉时间不能得到保证。总的来说经过一学期的“受虐”,自己还是学到了很多知识,经验和教训,希望学弟学妹能吸取我这个老学长的教训,愉快充实地学好软件工程三这门课,也希望自己能在以后的开发过程中注意以上的几点,开发出自己满意的项目。