软件工程第二次作业

  • 采访工业界的软件团队(通过邮件,微博,微信,阅读博客等方式),询问他们的软件开发流程
  • 分组讨论,
    • 投票选出你们小组成员最喜欢的两个团队类型
    • 辩论你们在这门课程中最应该采取哪种类型
    • 列出优劣

      (一)软件开发流程

      1.需求分析

      1.相关 系统分析员向用户初步了解需求,然后用相关的工具软件列出要开发的系统的大功能模块,每个大功能模块有哪些小功能模块,对于有些需求比较明确相关的界面时,在这一步里面可以初步定义好少量的界面。
      2.系统分析员深入了解和分析需求,根据自己的经验和需求用WORD或相关的工具再做出一份文档系统的功能需求文档。这次的文档会清楚列出系统大致的大功能模块,大功能模块有哪些小功能模块,并且还列出相关的界面和界面功能。
      3.系统分析员向用户再次确认需求。

      2.概要设计

      首先,开发者需要对软件系统进行 概要设计,即 系统设计。概要设计需要对软件系统的设计进行考虑,包括系统的 基本处理流程、系统的组织结构、模块划分、功能分配、接口设计、运行设计、数据结构设计和出错处理设计等,为软件的 详细设计提供基础。  

      3.详细设计

      在 概要设计的基础上,开发者需要进行软件系统的详细设计。在 详细设计中,描述实现具体模块所涉及到的主要算法、数据结构、类的 层次结构及调用关系,需要说明软件系统各个层次中的每一个程序(每个模块或 子程序)的设计考虑,以便进行编码和测试。应当保证软件的需求完全分配给整个软件。详细设计应当足够详细,能够根据详细设计报告进行编码。

      4.编码

      在 软件编码阶段,开发者根据《软件系统详细设计报告》中对数据结构、算法分析和模块实现等方面的设计要求,开始具体的编写程序工作,分别实现各模块的功能,从而实现对目标系统的功能、性能、接口、界面等方面的要求。在规范化的研发流程中,编码工作在整个项目流程里最多不会超过1/2,通常在1/3的时间,所谓磨刀不误砍柴功,设计过程完成的好,编码效率就会极大提高,编码时不同模块之间的进度协调和协作是最需要小心的,也许一个小模块的问题就可能影响了整体进度,让很多程序员因此被迫停下工作等待,这种问题在很多研发过程中都出现过。编码时的相互沟通和应急的解决手段都是相当重要的,对于程序员而言,bug永远存在,你必须永远面对这个问题!

      5.测试

      测试编写好的系统。交给用户使用,用户使用后一个一个的确认每个功能。软件测试有很多种:按照测试执行方,可以分为内部测试和外部测试;按照测试范围,可以分为模块测试和整体联调;按照测试条件,可以分为正常操作情况测试和异常情况测试;按照测试的输入范围,可以分为全覆盖测试和抽样测试。以上都很好理解,不再解释。总之,测试同样是项目研发中一个相当重要的步骤,对于一个大型软件,3个月到1年的外部测试都是正常的,因为永远都会有不可预料的问题存在。完成测试后,完成验收并完成最后的一些帮助文档,整体项目才算告一段落,当然日后少不了升级,修补等等工作,只要不是想通过一锤子买卖骗钱,就要不停的跟踪软件的运营状况并持续修补升级,直到这个软件被彻底淘汰为止。

      6.软件交付

      在软件测试证明软件达到要求后,软件开发者应向用户提交开发的目标安装程序、数据库的 数据字典、《用户安装手册》、《用户使用指南》、需求报告、设计报告、 测试报告等双方合同约定的产物。
      《用户安装手册》应详细介绍安装软件对运行环境的要求、安装软件的定义和内容、在客户端、服务器端及 中间件的具体安装步骤、安装后的系统配置。
      《用户使用指南》应包括软件各项功能的使用流程、操作步骤、相应业务介绍、特殊提示和注意事项等方面的内容,在需要时还应举例说明。

      7.验收

      用户验收。

      8.维护

      根据用户需求的变化或环境的变化,对应用程序进行全部或部分的修改。  维护是指在已完成对软件的研制(分析、设计、编码和测试)工作并交付使用以后,对软件产品所进行的一些软件工程的活动。即根据软件运行的情况,对软件进行适当修改,以适应新的要求,以及纠正运行中发现的错误。编写软件问题报告、软件修改报告。软件升级, 编辑需求,调整分析软件功能,拓展优化系统。

      举例解析

      编辑
      1 例如某家公司想找人订做一套 人事管理软件,从某种渠道上得知某家软件开发公司提供这种服务,所以进行联系。
      2 软件开发公司会派专门的 软件工程师到他们那里去了解我们要设计一个什么的东西给用户用,然后回来做个方案给他们,其中方案的内容包括:开发出来的软件大概的界面是怎样?方便什么人使用?什么人可以使用什么功能?方便到什么程度?大概的硬件要求是怎样等?
      3 用户看了方案后,确定他们就是要做一套这样的软件,开发方就开始开发这套软件。
      4 开发方把开发出来的软件交给用户使用,其中在使用的过程中哪里使用不方便或哪里达不到要求,开发方会第一时间修改这些功能,直到用户要求的所有功能都能很完美的解决掉。
      5 用户如果因为公司发展壮大的需要,需要将软件升级开发方会做功能拓展。

      (二)最喜欢的团队类型

          1.我比较倾向于交响乐模式。

          交响乐模式:门类齐全,各司其职,有共同方向的。其优点是在开发过程中分工明确,大家可以术业有专攻,效率比较高。缺点是适用于某歌软件领域处于稳定成长的阶段,如果是在刚开始的时候可能会产生分歧。
          功能团队模式:具备不同能力的同事们平等协作,共同完成一个功能,在这个功能完成以后,这些人又重新组织,和别的角色一起去完成下一个功能。

      2.列出优劣

                优点:

                 (1)效率高

                 (2)一出手就能解决别人解决不了的难题

                 (3)会成为其他一些技术不怎么好的员工的榜样,并帮助他人提高技能

                (4)交流一些好的技术,开阔眼界

               缺点:

                (1)在大家协作完成一个功能后去和他人组队,那么新的小组成员还需要一个磨合期来使对方熟知起来比较耗时间不稳定。

                (2)大多能力强的人都会有点心高气傲,这样的一群人聚在一起,会导致谁也不服谁,进而有损团队和睦

你可能感兴趣的:(软件工程第二次作业)