一、请回望暑假时的第一次作业,你对于软件工程课程的想象
1)对比开篇博客你对课程目标和期待,“希望通过实践锻炼,增强计算机专业的能力和就业竞争力”,对比目前的所学所练所得,在哪些方面达到了你的期待和目标,哪些方面还存在哪些不足,为什么?
达到的期待和目标
- 完整的体验了软工过程
- 团队一起推进完成一个可上线项目。
- 增强了自己的编码能力
- 增强了自己的文档撰写能力
- 第一次全面的了解了后端的框架
不足
- 在这次软工实践的过程中更偏向文档工作,编码提升幅度小
- 大多时候都想摸鱼
2)总结这门课程的实践总结和给你带来的提升,包括以下内容:
1、统计一下,你在这门软件工程实践中,完成了多少行的代码;
作业 代码量 个人作业 200 结对作业 300 团队项目 900 总计 1400 2、软工实践的各次作业分别花了多少时间?(做一个列表)
作业 时间(h) 第一次作业-准备 13 第二次作业 - 个人项目 10 第三次作业 - 原型设计 12 第四次作业 - 团队展示 7 第五次作业 - 结对作业二 12 第六次作业 - 团队选题报告 5 第七次作业 - 需求分析报告 12 第八次作业 - 现场UML设计 15 Alpha冲刺阶段 13 团队现场编程实战(抽奖系统) 6 福大软工 · 第十次作业 - 项目测评 4 Beta 冲刺阶段 6 最终作业 - 软件工程实践总结 2 总计 117 - 3、哪一次作业让你印象最深刻?为什么?
现场团队编程,自己菜不重要,重要的是队友知道你很菜。 - 4、累计花了多少个小时在软工实践上?平均每周花多少个小时?同时贴出开篇博客“你打算平均每周拿出多少个小时用在这门课上”的回答
117小时。算16周的话,每周超过7个小时.原博客回答“工作日每天1到1.5小时,周末每天3小时”比预期的每周少一个小时,勉勉强强及格吧。 - 5、学习和使用的新软件;
Visual Studio,office全家桶以及PCcharm。 - 6、学习和使用的新工具;
github,堪称神器。 - 7、学习和掌握的新语言、新平台;
增强了一点点C,一点点Python。Get到了Processon、leangoo等平台。 - 8、学习和掌握的新方法;
面向百度学习,面向GitHub交流。 9、其他方面的提升。
执行力、学习能力、开发能力、表述能力等,最主要的PPT制作能力。
二、写下属于自己的人月神话——个人或结对或团队项目实践中的经验总结+实例/例证结合的分析
- 在团队开发中,团队意识比其他都要来得重要,只有团队意识好了整个团队的状态才更加健康。比如,在团队项目初期,团队处于迷茫状态,彼此也没能很好接触沟通,导致一系列后续的事情都得不到团队的统一,更别说是执行了。
- 在结对项目中,好的队友非常重要,我和当时的队友就相处良好,分工迅速,推进也比较一致,结对项目自然也比较顺利。
三、对下一届实践的建议,或者对于开学初的你,对于大一的你,对于开学初的我,对于同期的TA们,对于后来的学弟学妹:
- 1)你有什么想建议、告知和期许想要告诉他们呢?
所有你水过的时间,水过的知识,偷过的懒都会在这门实践中狠狠的暴露出来,再砸到你的头顶。不要抱怨为什么安排这么多,多做事,多学习,少偷懒,终有所收获。年轻人趁着能熬夜的年龄多熬点夜也是一种财富呢(一条五毛)。 - 2)特别地,特别地,下一届要不要中途换队员(强制的、彻底的从一队换到另一队)?
假设依旧是一个90+人数的大班。不建议更换队员,甚至是团队解散。中途换队员,沟通成本增加,原本的计划会被略微打乱吧。 - 3)身在一个格外大的班级,竞争强劲,你认为一个组的人数应当在多少比较合适?
9-10人的团队人数在这里面真的是太多了,分工不好分,沟通成本也在增加,队员又会松懈,建议5-6人。 - 4)个人/结对/团队作业应该控制在怎样的规模?
个人作业和结对作业限制语言是真的蠢,我平时主要学习Python,为了做个人和结对作业还要再捡起来C++,花费很多时间,最终作业结果也不是很理想,建议改进。团队作业尽量控制在中等水平的团队能够在2周内能完成的水平。 - 5)这学期下来,你最感谢的人是谁?有什么话想要对TA说呢?
感谢我的pm,没有怨言,尽职尽责,认真负责,有你在真好。
四、分析一下自己所处的团队。软件工程实践是大学里少有的认真的团队协作经验。《构建之法》上说团队的发展有几个阶段,你的团队都经历过么,最后到达了“创造”阶段了么?(参考《构建执法》第17章 人、绩效和职业道德)
我任务我们团队已经经历萌芽和磨合阶段进入规范阶段。遗憾的是没有进入创造阶段。
五、怎样证明你学会了软件工程?
- 1)研发出符合用户需求的软件
草履记-一款记录、分享你旅游足迹、故事的产品。目前拥有73用户量(实际上并未正式进行推广),每天都有用户持续打开(特别少)。
必须公开发布,有实际的用户,一定的用户量和持续使用量 (3 天后能保持10 - 100个用户);而不是: 做没有用户使用的软件 - 2)通过一系列工具,流程,团队合作,能够在预计的时间内发布 “足够好” 的软件
通过leangoo每两天记录进度,例会,燃尽图等,让团队成员不仅了解自己的任务是什么,还了解自己项目应有的进度,以及和队友的任务进度对比。团队分工较均衡。
有项目规划/需求/设计/实现/发布/维护,有定时的进度发布 ; 而不是: 通过临时熬夜,胡乱拼凑,大牛一人代劳,延迟交付等方式糊弄 - 3)并且通过数据展现软件是可以维护和继续发展的。
团队建设有功能优先图,UI规范文档,Bugs清单以及优化清单,通过github展示维护代码。
而不是 找不到源代码,代码无文档,代码不能编译,没有task/bug 等项目的发展资料 - 4)对着这个检查表:http://xinz.cnblogs.com/p/3852177.html 检查一下,自己如果去企业面试,这些常见的问题是否都能回答,并在此总结。
很多问题无法回答,主要原因是平时不注重细节,没有时常总结。在接下去的经历中,会吸取教训。
请在随笔中用数据证明上述内容或侧重选择之一。
六*(选做)、阅读软件工程中关于代码质量的的经典论文,从下列文献中选择一篇或若干篇,结合自己的实际做一个阅读笔记(例如,自己写的代码质量如何,是不是一个大泥球,如何衡量自己代码的质量)?从以下参考论文中选择一篇或若干篇:
参考论文文献:
[1] Stamelos I, Angelis L, Oikonomou A, et al. Code quality analysis in open source software development[J]. Information Systems Journal, 2002, 12(1): 43-60.
[2] Boehm B W, Brown J R, Lipow M. Quantitative evaluation of software quality[C]//Proceedings of the 2nd international conference on Software engineering. IEEE Computer Society Press, 1976: 592-605
[3] Samoladas I, Stamelos I, Angelis L, et al. Open source software development should strive for even greater code maintainability[J]. Communications of the ACM, 2004, 47(10): 83-87