软件工程实践总结(个人)

痛并快乐着——软件工程实践总结(个人)

一、请回望暑假时的第一次作业,你对于软件工程课程的想象

1)对比开篇博客你对课程目标和期待,“希望通过实践锻炼,增强计算机专业的能力和就业竞争力”,对比目前的所学所练所得,在哪些方面达到了你的期待和目标,哪些方面还存在哪些不足,为什么?

一学期走来,感觉还是学了很多东西的。从刚开始听到打代码就头疼,到现在能够独立地完成一些有挑战性的个人作业,成就感还是满满的。虽然到现在我还是希望将来能够少写代码,但通过一学年的学习,我也知道,能少打代码意味着已经有了一定的代码基础。而且从事这一行业,不可能不打代码。因此,软工实践以来的苦逼和痛,或许会在将来成为意想不到的助力。

学到现在也有很多不足,比如当时希望能做出一个很耐看的界面,后面也只是草草了事。理想和现实的差距,往往体现在能力的不足和人的惰性身上,也希望以后能够精益求精,对任何事情都能交出完美的答卷。还有很不足的地方,就是到现在都没能习惯使用github,以及代码规范。

2)总结这门课程的实践总结和给你带来的提升,包括以下内容:

1、统计一下,你在这门软件工程实践中,完成了多少行的代码;

作业序号 代码量 备注
1 300 个人作业-词频统计
2 200 第二次结对作业
3 1500 Alpha冲刺阶段
4 100 团队作业-项目测评
5 300 团队现场编程-抽奖系统
6 1000 Beta冲刺
总计 3400

2、软工实践的各次作业分别花了多少时间?(做一个列表)

作业名称 耗时(h) 做了啥
软工实践第一次作业 2 学了makedown格式,看看博客,写写博客
个人作业-词频统计 20.5 学习单元测试等新知识,复习c++,问同学,
第三次作业-结对作业(原型设计) 8 学习并使用Axure RP 8
第四次作业 - 团队展示 1 交博客,增加个人部分
第五次作业 - 结对作业2 16 用python爬数据,实现一些附加功能
第六次作业 - 团队答辩 0.5 交博客,增加个人部分
项目UML设计 5 学习ProcessOn、UML设计,绘制用例图
需求分析报告 10 用墨刀设计原型
Alpha 冲刺 80 原型的重新设计,前端界面的设计,AR技术的研究,拍摄数据集,标数据集,做PPT,研究特效,详见各次冲刺学习进度条,写博客
团队现场编程实战(抽奖系统) 7 python学习和熟悉,聊天记录的分析和挖掘
项目测评(团队) 6 上台答辩,做ppt,采访和测试部分工作
Beta 冲刺 10 对前端界面进行优化,标数据集,拍数据集,参与PPT的制作
个人总结 4 写博客
总计 190

3、哪一次作业让你印象最深刻?为什么?

应该是第一次个人作业吧。那是我第一次接触到这么庞大的代码量,以及要学这么多的的新东西,单元测试,github的使用等等。这些都让我感觉头疼和不适应。而且不同于结队作业,我要一个人完成整个作业,其中不乏我非常不擅长的部分。虽然最后得分不高,但是我从中也收获了很多宝贵的经验,算是痛并快乐着吧。

4、累计花了多少个小时在软工实践上?平均每周花多少个小时?

  • 如果算上站立会议时间和课程答辩时间的话,大概在210小时吧
  • 软工从开学第一周到十七周基本结束,共17周,平均210/17=12.3个小时

5、学习和使用的新软件;

  • visual studio 2017 :开发c++控制台程序,第一次个人作业使用
  • Android studio 3.0.0 :andoid开发基本工具,用来做界面
  • Axure RP 8:原型设计
  • Sublime Text 3:使用python爬网站数据
  • PowerPoint:做ppt
  • Typora:群里老哥推荐,用来makedown的工具

6、学习和使用的新工具;

  • github:学了,但是并没有习惯运用

7、学习和掌握的新语言、新平台;

  • java:从0开始,还好可以向身边同学学习
  • python:爬爬数据,画画图,需要什么功能学什么
  • github:download代码,用来学习
  • Process On:一个在线画流程图/uml图等的平台,在需求分析阶段尤其好用

8、学习和掌握的新方法;

  • 用例图:基于场景来考虑分析问题,更有助于我们了解需求
  • 思维导图:用思维发散的理论,基本覆盖了要做的所有任务集,用图来表示清楚美观

9、其他方面的提升。

  • 除了技术硬能力方面,和同学的团队合作也提高了我的团队协作能力和交际能力;
  • 每次在deadline前肝博客提高了我的熬夜能力;
  • 答辩和博客提高了我的沟通能力和瞎编能力;
  • 碰到不会的部分提高了我的学习能力和抗打击能力......
  • 学习这门课真是好处多多,学弟学妹们一定要选柯老师(划重点!)

二、写下属于自己的人月神话——个人或结对或团队项目实践中的经验总结+实例/例证结合的分析

  • 第一次个人作业的时候,只有痛苦,没有快乐。那种直到deadline,却始终交不出东西的感觉,是很难受的。现在想来,失败的原因除了代码经验过少之外,对软工不够重视(其实很重视了,但是没想到还不够重视)是更主要的原因。没有付出足够的努力和时间,自然不能保证得到满意的结果。
  • 结对作业的完成还是比较流畅的。因为我c打的不好,所以主体功能还是由队友完成的。我负责用爬虫爬数据,也学到了一些有用的技能。比较可惜的是最后程序似乎有点小bug,得分点并没有全部得满,还是有点可惜的。
  • 团队作业过程中真的学到了很多,算是把软件工程理论课所学到的东西几乎都能付诸实践。不止是技术上的,还有答辩能力和团队协作能力。因此,假如你经得起软工实践的挑战的话,还是能从中受益颇多的。

三、对下一届实践的建议,或者对于开学初的你,对于大一的你,对于开学初的我,你有什么想建议和告知的呢?对于后来人的期许。 特别地,特别地,下一届要不要中途换队员?

(1)对下一届学弟学妹们(和开学初的我)的建议和告知:**

我希望他们能学会合理分配自己的时间。软工实践的确是一门可以学到很多东西的课,但是同时也意味着占据了很多课余时间,如果不能妥善处理,那么很可能一事无成。我也希望他们能够做到我们这届做不到的东西,能够做出真正能面向市场的软件。

(2)特别地,特别地,下一届要不要中途换队员(强制的、彻底的从一队换到另一队)? 假设依旧是一个90+人数的大班

我认为可以有中途换队员的操作,但是没必要强制。因为有的人可能并不能适应这种被迫换队的操作,虽然在社会中可能会出现这样的情况,也的确有锻炼的效果。但倘若因为这种原因而完成不了软工实践(下学期他们还是必修)的话,这就是一件很尴尬的事情了。

(3)身在一个格外大的班级,竞争强劲,你认为一个组的人数应当在多少比较合适?

8-10人吧,我觉得按这学期的人数划分就很合理了。真的想完成一个比较完善的软件,4-5人是远远不够的。

(4)个人/结对/团队作业应该控制在怎样的规模?

软工真是个神奇的存在。在做作业的过程渴望作业少点,但到了现在又觉得这些作业量是合理的,也的确能够锻炼人。但还是希望能够尽量给学生足够的自主性,不要过分影响大学的其它精彩的组成部分。

(5)这学期下来,你最感谢的人是谁?有什么话想要对TA说呢?

喜源同学,我的结队队友和团队队友。到了计算机以来,很多实践基本都是和他组队,而且说实话,他带我飞的次数会比我带他要多很多。最想对他说一句由衷的谢谢。还有说过请他吃饭的事情一定会兑现诺言的。

四、分析一下自己所处的团队。软件工程实践是大学里少有的认真的团队协作经验。《构建之法》上说团队的发展有几个阶段,你的团队都经历过么,最后到达了“创造”阶段了么?(参考《构建执法》第17章 人、绩效和职业道德)

  • 萌芽:团队的起源源于队友暑假打的一个比赛,既然比赛有一个成功的算法雏形,我们当然愿意参与其中。知道这个团队的组成还是很开心的,因为很多都是以前听说的学霸,自然而然地就以为可以在里面舒舒服服地被带飞。可惜在软工实践中,这是不可能的,想要得到好成绩,就要付出努力。
  • 磨合:刚开始的团队磨合还是会有一些小问题的。开始的几次会议简单确定了接下来的方向,在一次决定分工的群投票中,由于选择的太晚。最后迫于无奈被分入的开发组。但想到大家基本都是0基础,都得从头开始学,也没什么怨言。后来的合作基本流畅,当然也出现过因为贡献度分配的问题而产生争执的情况。我觉得这是很合理的,并不是一件坏事,理越辩越明,这会让我们团队合作更加紧密。
  • 规范:这大概是我们团队目前的现况吧。分工明确,责任和协作人清晰可查。组长的统筹也很合理,并且具有执行力。当然,在代码上的规范还是远远不够的。
  • 创造:现在团队还没有到创造的阶段。每个人做的基本都是自己的工作,很少有个人能够在各个模块都有一定贡献,并提出创造性的想法。整个团队虽然有创造力,但是远远称不上一个创造阶段的团队,我们也没有能力去执行我们的创造性想法。

五、怎样证明你学会了软件工程?

1)研发出符合用户需求的软件

我们团队开发的产品是面向大学生使用的,现在暂未投入市场,但经过我们小组内部使用和前期投放的问卷调查,这一产品还是比较受市场欢迎的。

2)通过一系列工具,流程,团队合作,能够在预计的时间内发布 “足够好” 的软件

我们队用燃尽图等手段,定时查看每个队员的“生产进度”。采用原型设计模型,拥有良好的团队协作,足够保证能在预计的时间内发布“足够好”的软件。

3)并且通过数据展现软件是可以维护和继续发展的。

我们团队有足够详细的文档说明和源码,易于维护和继续发展。
补充一下图片:

4)对着这个检查表:http://xinz.cnblogs.com/p/3852177.html 检查一下,自己如果去企业面试,这些常见的问题是否都能回答,并在此总结。

大部分都不能回答,看来我的专业水平离一个程序员的标准还是远远不够啊。

六*(选做)、阅读软件工程中关于代码质量的的经典论文,从下列文献中选择一篇或若干篇,结合自己的实际做一个阅读笔记(例如,自己写的代码质量如何,是不是一个大泥球,如何衡量自己代码的质量)?从以下参考论文中选择一篇或若干篇:

论文名:Open source software development should strive for even greater code maintainability

引用:(百度翻译后的)

随着年龄的增长,预计OSS项目会有类似的行为是很有道理的:OSS方法将以与CSS相同的方式产生遗留系统。因此,OSS系统也需要适当的重新设计操作。换句话说,预防性维护可能是OSS支持者必须考虑的第三种维护类型。需要更多的实证分析来巩固这项研究的发现。我们将继续监控这些项目的质量,并将我们的分析扩展到其他OSS项目,这些项目预先发送了有趣的特性,并允许与CSS开发进行比较。但是,从OSS系统用户感知质量的角度来整合OSS质量的结构视图是非常重要的。

虽然简单地浏览了一遍,但是并没有很透彻地理解文章的意思。本文着力于oss与传统css的比较,多次提到了可维护性的概念。软件工程中也反复提到可维护性的概念。从可维护性的角度来看,不止是能更容易地发现bug,更是为今后扩充功能打好基础。这不仅需要严格的代码规范和注释,也需要有效的配置管理,这方面我们团队做的还是比较粗糙的。同时我也发现,现在百度翻译做的真的不错,翻译出来的效果基本和原意差的不是很多。当然,对一个程序员来说,学会看英文论文也是必须的,这个还需要加强学习。

七、个性发挥,包括图文、照片和创意等

团队的第一次合影,希望我们团队能保持初心,始终如一。

不知道说些啥,那就新年快乐(期望考试高分)吧>_<
img

posted @ 2018-12-29 21:13  福大魔王  阅读(2500)  评论(3编辑  收藏  举报