031302517  031302319

ps:共同完成一篇随笔,文章中的第一人称我(517),队友(319)

一、功能分析+实现思路+结队讨论

  这里我将功能分析和实现思路还有结对过程中的一些讨论结合在一些来写。因为我等会写的内容可能会在功能分析和实现思路这两者间来回切换,可能会在某一功能的分析之后紧接着实现思路,也可能会写很多的思路,但可能跟功能没什么关系,还有可能写了一堆类似废话的结队讨论。总之我是想起来什么,就赶紧写下来的。讲述上的逻辑可能会有些乱,看看就好,不要计较。最后会给出个小小的总结。好了,下面先来看看这次的功能需求:

  好了,上述的功能描述已经很详细了,也就是实现两个功能,一是导入excel表格到数据库,二是从数据库中拿数据。那我们在这里需要对这两个功能分析些什么呢?首先,我觉得我们得先定位下自己项目的系统。什么意思,很简单,你的系统要怎么实现,你的数据库放在哪,你要做成有服务器端来提供数据库供你存取数据,还是说利用安卓自带的数据库,以及在程序后台实现导入。

  在我看来,这是两种可行的思路。而且我一开始就打算采用第二种,即安卓自带的数据库。然而在跟队友讨论项目时,却出现了矛盾。队友跟我说,老师要我们导入数据库肯定就是要导入服务器端的啊,你导入什么安卓自带的系统,那有什么意义啊?又不能共享,难不成你要做成导入数据库的Excel数据只能你自己使用吗?这样的话,你直接解析完Excel就把数据拿去展示不就行了,还特意存入数据库不是多此一举吗?说得好像很有道理,然而仔细想想,Excel数据有要求一定要共享吗?我们增添类似分析数据或者发送邮件的功能不行吗?最后说服队友是,时间不够用。相对于采用服务器端的数据库,安卓自带的SQLite不管是学还是用都教为简单。

  下面先来几张图,不然又是一大堆文件(下图是我们小组在进行界面的改善)
【作业三】结队任务二-----CourseManagement-LMLPHP【作业三】结队任务二-----CourseManagement-LMLPHP

  好了,数据库的方式定下来了。接下去也就是要开始分工了。这里插点后话,结队如何共同完成项目,如何分工这在前期一定要讨论清楚。这次结队下来才发现,由于事先没有统一项目的实现细节,导致两人的学习点完全相反,比如关于数据库我学习的是SQLite,然而队友却是学习的Mysql;还有就是没有规定好统一开发环境,导致clone github项目时报错一大堆,程序根本无法跑起来。当然,这也有我把.idea也push到github的原因;最后就是没有统一好编码规范,导致队友在阅读我代码时困难重重,尤其是队友为了能按时完成,居然熬夜到半夜三点多,都是我的错,以后一定好好命名,好好注释,好好规范,好好讨论。还好的是,这些问题在中期都被发现并趁早解决了。当然,这些都是后话了,但还是得写出来警戒下自己。下面就说说我们的分工,我负责的是excel的解析并导入,还有界面的编写。队友负责的是数据的导出并展示。因此,前期代码的编写基本是我负责,后期则交由队友来完成。刚好,我之前稍微接触过其他语言,学安卓速度快点,队友正好可以借前期由我负责的时间来学习相关知识。

  写完分工,下面就写写功能的实现思路,首先是我负责的部分:(1)解析Excel(2)导入数据库(3)界面编写。要将Excel导入数据库,首先就要对Excel进行解析,就在大家都疑惑安卓能否打开Excel时,立即就有大神给出了思路:jxl.jar,这是一个第三方的库,支持安卓程序对Excel的基本操作。然而作死的我却选择的Apache POI,想搞点特殊的,装装13。当稍微看了些文档,照例子实践时却发现报了一堆错,解决一个又冒出一个,最终考虑到时间因素,实在无法在这部分继续耗下去,果断重新选择jxl.jar。果然,装13也是要看脸的。jxl.jar提供了一些API,供我们对Excel的打开,读取。解析的功能实现了,接下去就是导入。因为选择的数据库是SQLite,它提供的很多接口,可以实现对数据库的CRUD操作。最后就是界面的编写了,因为我们原型设计里采用了列表以及二级列表的形式,所以安卓可以用ListView和ExpandableListView实现。以上,就是我负责部分的实现思路以及我要学习的知识点了。

  下面看看队友负责的部分:(1)导出数据库(2)展示数据。看看队友的思路,下面是他的原话:

    

·写了这么多没头没尾的看着又好像废话的想法,下面就来张表总结下:

【作业三】结队任务二-----CourseManagement-LMLPHP

二、APP界面展示及其他截图

  首先是 Excel文件的打开,点击Excel文件,选择我们的APP进行打开,我们组只提供这种方式进行打开,对于那些还实现了文件管理器,文件扫描的大神们,表示向往。下图就是选择我们APP以及用我们APP打开Excel后显示的页面:

【作业三】结队任务二-----CourseManagement-LMLPHP【作业三】结队任务二-----CourseManagement-LMLPHP

  点击计算机 1.xls,进入详情页面查看。如下图:

【作业三】结队任务二-----CourseManagement-LMLPHP【作业三】结队任务二-----CourseManagement-LMLPHP


下面是我们小组在结队编程中碰到的问题:

【作业三】结队任务二-----CourseManagement-LMLPHP

【作业三】结队任务二-----CourseManagement-LMLPHP
以上图是由于开发环境不同导致的冲突和编码没有事先统一细节出现的冲突

【作业三】结队任务二-----CourseManagement-LMLPHP
以上图是我们小组的commit记录,前期是我负责,后期则交由队友,最后我再进行整合成最终版。

附上我们的Github项目链接CourseManagement

三、PSP表格以及小结

Planning计划7天7天
Estimate估计这个任务需要多少时间7天(老师给的期限)7天
Development开发7天(天天都在码)7天
Analysis需求分析(包括学习新技术)5天(前期基本都在学)4天
Design Spec生成设计文档1小时没预计这个
Design Review设计复审1小时3小时
Coding Standard代码规范0.5小时(我知道错了)忘记做个了
Design具体设计1天半天
Coding具体编码7天(还是天天码)6天
Code Review代码复审2小时8小时
Test测试(自我测试,修改代码,提交修改)0没有做这个
Reporting报告3小时
Test Report测试报告0
Size Measurement计算工作量1小时
Postmortem & Process Improvement Plan事后总结, 并提出过程改进计划2小时1小时

最后附上队友对于这次结队的心得和小结:

05-11 09:21