泰斗科技软件开发基本流程

基本流程

流程(标准)是做事步骤,是如何做和做的结果,是执行力的体现。

  本部分描述泰斗科技基本开发流程,具体工作结果的界定,可本着简单实用的原则根据实际工作进行细化,并补充为本流程的实施细节要求。流程本质可归纳为“输入-处理-输出”过程,开发流程的“输入-处理-输出”过程简要划分为六个阶段,过程示意如下:

输入

处理

输出

需求确认

界面确认

系统设计

功能开发

系统测试

软件交付

流程并不是完全瀑布式的,各阶段可适当迭代交叉进行;各阶段内都应遵循MVP(最小化可行产品)原则,紧紧围绕主流程不断完备本阶段交付物。

  流程的实施应遵循“先僵化、后优化、再固化”的原则,在执行过程中完善和巩固。在执行过程中,对于大家一致认可、不可二犯的错误,一犯后要反思并约定二犯时的惩罚措施。

需求确认阶段

  (1)需求面对面沟通:现场感的描述;

  (2)需求分析文档:主要体现项目背景和目标、业务流程(图)、现场感的业务描述(案例描述)、各角色功能清单、主要界面草图;

  (3)需求确认文档:客户代表签字;作为项目合同附件;

  (4)项目合同:合同金额、支付方式、违约责任,界面原型设计周期、功能开发周期、部署交付周期,销售、设计、开发三方经理沟通项目风险并确认合同内容,客户确认。

  工具:需求分析文档模板、项目合同模板、各确认文档模板、项目风险分析文档模板。

界面确认阶段

  理念:界面即结果,客户要的是结果!开发瞄准的也是结果!

  (1)界面原型草图:纸上原型(手工线框图),体现各角色操作流程;

  (2)高保真界面原型:H5界面,无后端逻辑代码的真实软件,前端即软件;体现各角色真实操作流程和界面效果;与后端无缝对接的代码架构;

  (3)原型确认文档:原型交付、沟通调整,客户确认。

  工具:纸上原型、H5/jQuery、UI框架/模板。

  备注:本阶段可称为前端设计/开发阶段,需要需求分析、美工、前端开发等能力的集成。可交叉进行数据结构设计、架构设计和关键技术探索,但就是不写后端逻辑代码。

系统设计阶段

  (1)数据库设计:数据库表结构文档、数据库初始化SQL脚本;数据库实际是数据结构,是软件的高度抽象,是系统业务的灵魂,是架构设计和代码开发的根基,设计阶段要极度重视!

  (2)代码架构设计:逻辑模块分解(Solution/Project/Package)、目录结构设计、主要程序文件名确定;CodeFirst实体类代码生成;

  (3)交互接口设计:前后/端交互接口设计(如JSON数据格式、QueryString传参内容)、核心函数接口设计;

  (4)关键技术突破:公共基础代码编写(要逐步模板化,如认证、权限、日志、异常处理),关键点/难点技术突破、易错问题预先避免的设计。

  工具:数据库设计规范、代码架构设计规范、交互接口设计规范、代码自动生成工具、项目代码模板;

  备注:不要把架构师或系统设计想得太高大上,预估程序员的能力及其可能出错的问题,提醒程序员并在设计上尽力避免出错的可能性,就是设计。避免问题,总比解决问题简单。凡事预则立,不预则废!

  我们交付的是功能,不是代码。代码是个无底洞,越晚动手越好。代码的过早付出,会带来负面情绪。因为懒了脑子,所以累了身体。本质还是先动脑再动手,克制不动脑子蛮干的冲动。

  不过度设计,但不能不设计。不能以“敏捷、试错”的名义不设计、不思考、不想静静!

  再次提醒:架构师的心中要有项目全局,深度理解需求、怀揣完整流程、深刻理解技术,设计时又不能陷入技术实现细节。设计是设计,实现是实现,思想上要切割。要适度考虑实现,切不可为了实现扭曲了设计。

功能开发阶段

  (1)进度清单:进度清单(进度优先级),任务分工,里程碑节点;进度清单更新频率;

  (2)日会制度:前一天做了什么;今天准备做什么;遇到了什么问题。项目经理应时刻   (3)任务细分:项目经理要将开发模块任务细分,明确任务效果——逐条列出任务效果要求,并不断检查任务效果。

  (4)主流程畅通:优先实现主流程,紧紧围绕主流程,确保主流程畅通;优先解决关键路径上的关键问题;

  (5)面向界面编程:界面即结果,结果倒推过程。开发人员要面向界面编程、面向接口编程。

  (6)用注释理思路:找到设计感,理清思路再动手,画草图理流程,列出实现步骤,一定要克制一头扎进代码堆里的冲动!

  (7)自我测试:小步前进,不断测试;步子足够小,不用Debug;单元测试(尝试);

  (8)版本控制:开发与交付版本分离控制;

  (9)一键发布:实现一键发布、自动化部署。

系统测试阶段

  (1)主流程测试:不断测试主流程、梳理优化主流程;与开发迭代进行;

  (2)系统功能全面测试:人工测试,可用性测试,边界测试;

  (3)上线运行试用:部署文档;针对特殊系统的应用情况自动记录报告;

  (4)Bug追踪管理:Bug记录,Bug处理,统计分析。

软件交付阶段

  (1)软件发布包/安装包;

  (2)软件部署手册;

  (3)用户使用手册:分角色描述,体现业务流程;

  (4)售后服务:客户沟通与反馈处理。 

      

文章部分内容来自网络,如有侵权请联系泰斗科技,进行删除!谢谢!

泰斗科技







































北京白癜风医院治疗
白癜风怎么治最好



转载请注明地址:http://www.henanledxianshiping.com/jwrjgcs/3433.html
  • 上一篇文章:
  • 下一篇文章: