我们的项目是自选项目,一款名为备忘录锁屏MemoryDebris的软件。

  因为我们组成员在此之前都没有接触过安卓开发,于是在第一阶段花了很大的时间和精力学习安卓。又花费了较长一段时间设计软件与研究安卓锁屏机制。

  基于我们的基础,我们对第一次迭代开发的结果相对满意,并深深认同每一位团队成员对我们团队的付出,在此做一些总结,希望第二轮迭代可以走的更远。

一、小组成员在M1阶段的贡献

顾育豪:很尽责的PM,组织能力优秀;与王洛书组队,完成锁屏模型设计与实现;后期负责锁屏模块的连接工作;……。

刘强:实现对手机短信数据库的访问,调用;设计了备忘录,读书笔记的数据库结构,编写了数据库的控制接口;添加了前台界面的事件监听;……。

王洛书:与顾育豪组队,完成锁屏模型的设计与实现;负责编写用户选择是否锁屏部分的代码;编写图片导入模块;市场宣传;……。

黄明源:很好的dev与designer,主要针对软件UI进行设计与制作,编写xml文件。其他工作如修改小bug,软件图标,各部分连接时候提供帮助;……。

陈睿翊:对软件进行测试并提出改进意见;部分博客的撰写;……。

张梦达:审美一流的设计者,负责团队美工方面;市场宣传;……。

二、小组成员M1阶段的分数分配

王洛书 21.5分

顾育豪21分

刘强20.5分

黄明源:19.5分

张梦达:19分

陈睿翊:18.5分

 三、总结

3.1设想和目标

1、我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述?

我们要做一个能够帮助人们利用解锁屏幕时间的软件。便捷地将每天需要记忆地内容呈现在锁屏界面,让用户根据自己的需求设置、记忆。

定义的很明确。

典型用户:学生、商人、学者等

典型场景:

   “解锁屏幕的时候,是不是可以提醒一下自己今天的任务清单是什么?

是不是可以再背一遍今天在书上看到的巧妙算法?

是不是可以再看一看presentation的提纲?

是不是可以再温习一下某个朝代重大事件?

是不是可以再记一下今天要背的生词?

是不是可以再记忆一下等会儿谈判的要点?”

 

2、是否有充足的时间来做计划?

有,我们在第一轮迭代开发时花了1-2周的时间来做计划。

3、团队在计划阶段是如何解决同事们对于计划的不同意见的?

开会讨论不同意见,大家评价哪种想法更好。事实证明,我们的方法很有效,大家对产品设计产生过很多分歧,但是最后都通过讨论达到共识。

4、用户量, 用户对重要功能的接受程度和我们事先的预想一致么? 我们离目标更近了么?

有什么经验教训? 如果历史重来一遍, 我们会做什么改进?

一致,我们对现在2000+的下载量表示满意。

我们的经验是前期分工太乱了,让大家一起做一个项目,如果重来一遍,我们会更明确分工内容。

3.2计划

1、你原计划的工作是否最后都做完了? 如果有没做完的,为什么?

完成了。

2、有没有发现你做了一些事后看来没必要或没多大价值的事?

没有。

3、是否每一项任务都有清楚定义和衡量的交付件?

是。

4、是否项目的整个过程都按照计划进行?

是。

5. 在计划中有没有留下缓冲区,缓冲区有作用么?

有缓冲期,缓冲期让我们有充足的时间应对计划之外出现的情况。

6. 将来的计划会做什么修改?(例如:缓冲区的定义,加班)

我们学到了什么? 如果历史重来一遍, 我们会做什么改进?

增加缓冲期的长度,更注重界面的设计和风格的统一。

3.3资源

1、我们有足够的资源来完成各项任务么?

资源较少,因为我们的选题是一块市场相对空白的领域,网上几乎没有公开的可供参考的代码。

2. 各项任务所需的时间和其他资源是如何估计的,精度如何?

大家坐在一起讨论分析,在大体时间把握上不错,但细节精度不太准确。

3. 测试的时间,人力和软件/硬件资源是否足够? 对于那些不需要编程的资源 (美工设计/文案)是否低估难度?

是。我们低估了美工设计的难度。刚开始写会议总结时分工也有点乱,下一轮会改进。

4. 你有没有感到你做的事情可以让别人来做(更有效率)?

暂时没有团队成员提出。

3.4变更管理

1. 每个相关的员工都及时知道了变更的消息?

是,我们建立了QQ群,每天都会在群里沟通,每周也会在现实里组织开会。

2. 我们采用了什么办法决定“推迟”和“必须实现”的功能?

通过去掉这个功能,用户体验会降低的程度和程序是否还能正常运行来判断。

3. 项目的出口条件(Exit Criteria – 什么叫“做好了”)有清晰的定义么?

有。

4. 对于可能的变更是否能制定应急计划?

能。

5. 员工是否能够有效地处理意料之外的工作请求?

能够,我们完善地应对了很多次突发状况。 比如说团队成员生病、发现实现难度有些大、部分Bug修复困难等,最后都很好的解决了。

3.5设计/实现

1. 设计工作在什么时候,由谁来完成的?是合适的时间,合适的人么?

设计工作是第一轮迭代时,大家一起讨论设计,再分工完成每个人自己的部分的。很合适。

2. 设计工作有没有碰到模棱两可的情况,团队是如何解决的?

有,投票决定。

3. 团队是否运用单元测试(unit test),测试驱动的开发(TDD)、UML, 或者其他工具来帮助设计和实现?这些工具有效么?

有,有效。

4. 什么功能产生的Bug最多,为什么?在发布之后发现了什么重要的bug? 为什么我们在设计/开发的时候没有想到这些情况?

把设置的内容显示在锁屏上,需要考虑屏蔽安卓自带的锁屏功能,有时一不小心会出bug。

发布之后发现v1.0只能支持4.0以上版本,我们在编码时由于缺乏开发经验,并没有想的这么全面。

5. 代码复审(Code Review)是如何进行的,是否严格执行了代码规范?

我们在初期采取的是把6个人分成3组,进行两两结对编程,一边编程一边复审。

3.6测试/发布

1. 团队是否有一个测试计划?为什么没有?

有测试计划,很有用。

2. 是否进行了正式的验收测试?

进行了。

3. 团队是否有测试工具来帮助测试?

有。

4. 团队是如何测量并跟踪软件的效能的?从软件实际运行的结果来看,这些测试工作有用么?应该有哪些改进?

大多是人工检测,通过判断是否和预期一致检查性能。这些测试工作挺有用的,后期应多借助一些工具。

5. 在发布的过程中发现了哪些意外问题?

发现部分网站审核时间过长,失算。

四、总结

 

事后分析报告(M1阶段)的更多相关文章

  1. M1事后分析报告(Postmortem Report)

    M1事后分析报告(Postmortem Report) 设想和目标 1. 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们项目组所开发的软件为一个基于Andro ...

  2. M1事后分析报告

    在得到M1团队成绩之后,每个团队都需要编写一个事后分析报告,对于团队在M1阶段的工作做一个总结. 请在2015年11月24日上课之前根据下述博客中的模板总结前一阶段的工作,发表在团队博客上,并在课上的 ...

  3. M1事后分析报告--We have power to change the origin state

    M1事后分析报告 设计与实现 我们发的软件解决的问题?是否满足后面小组的要求?是否能够完全拟合前期目标? 答: 前期我们的软件完成量并不是特别让人满意,我们组在完成这些任务量之后,发现有很多地方是在做 ...

  4. Alpha阶段事后分析报告

    每个团队编写一个事后分析报告,对于团队在Alpha阶段的工作做一个总结. 请在2016年11月24日上课之前根据下述博客中的模板总结前一阶段的工作,发表在团队博客上,并在课上的事后分析会上进行汇报,并 ...

  5. 事后分析报告(Postmortem Report)要求

    在得到M1 团队成绩之后, 每个团队都需要编写一个事后分析报告,对于团队在M1阶段的工作做一个总结. 请根据下面的模板总结并发表博客: http://www.cnblogs.com/xinz/arch ...

  6. 事后分析报告(M2阶段)

    我们的项目是自选项目,一款名为备忘录锁屏MemoryDebris的软件. 在第二轮的迭代中,由于各科的大作业都集中在这一段时间,所以这段时间各个组员间的负担都比较大,但是在大家共同努力,最终我们还是交 ...

  7. M2事后分析报告

    设想和目标 1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 这次M2预想的就是解决3个主要问题,1:增加查询自己购买或者发布记录的功能,2:优化 所有的网络连接 ...

  8. 团队作业10——项目复审与事后分析(Beta阶段)

    一.Beta阶段项目复审 http://www.cnblogs.com/womenshuodedoudui/p/7001208.html 二.事后诸葛分析 http://www.cnblogs.com ...

  9. Postmortem Report 第一轮迭代事后分析报告

    一.设想和目标 1.1 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件<BlueZ>是一款全新动作类塔防游戏.与市面上已经存在的塔防游戏不同 ...

随机推荐

  1. hbase 各个概念,region,storefile

    HBase中有两张特殊的Table,-ROOT-和.META. .META.:记录了用户表的Region信息,它可以有多高region(这的意思是说.META.表可以分 裂成多个region,和用户表 ...

  2. Linux下yum安装MPlayer 或 LVC视频播放器

    添加第三方源 su -c 'rpm -ivh http://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-stable.noar ...

  3. 《你是我的小羊驼》游戏ios源码

    <ignore_js_op> <ignore_js_op> <ignore_js_op> <ignore_js_op>源码下载:http://code. ...

  4. xls数据导入sqlite数据库

      protected void btn_ok_Click(object sender, EventArgs e)     {         try         {             st ...

  5. cassandra 之 jdbc 使用【java、scala】

    1.数据库创建 参考接上文cassandra入门 http://www.cnblogs.com/piaolingzxh/p/4197833.html 2.下载jdbc驱动源码,构建jar包 源码下载地 ...

  6. php下使用phpmailer发送邮件

    由于默认虚拟空间不支持mail()函数,客户需要留言发送邮件,找到phpmailer发送不成功,调试成功后记录一下. 最新的下载地址在github,https://github.com/Synchro ...

  7. 新成员!Visual Studio Code --跨平台的开发工具(支持OSX, Linux 和 Windows)

    原文出处:新成员!Visual Studio Code --跨平台的开发工具(支持OSX, Linux 和 Windows) 这是我的文章备份  http://www.dotblogs.com.tw/ ...

  8. 【摘抄】Application.StartupPath和System.Environment.CurrentDirectory的区别

    System.Environment.CurrentDirectory的含义是获取或设置当前工作路径,而Application.StartupPath是获取程序启动路径,表面上看二者没什么区别,但实际 ...

  9. jquery.unobtrusive-ajax.js源码阅读

    /*! ** Unobtrusive Ajax support library for jQuery ** Copyright (C) Microsoft Corporation. All right ...

  10. [转]ORACLE的ProC用法讲解

    pro*c是高级的用法,OCI是oracle的基础用法 如何编译.pc文件: proc code=cpp  parse=none iname=filename.pc oname=filename.cp ...