热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

博客_团队博客第二周——DIG

团队博客第二周——DIG修改完善上周提交的需求规格说明书

团队博客第二周——DIG


修改完善上周提交的需求规格说明书


服务人群的改变

考虑到我校特有的保密性质,经小组讨论修改应用人群,从大众转向特定局部网络下的特定人群,例如:军人、秘密基地、山区等

修改应用场景


  • 用户场景A:军人小伟和小邹在一个特殊的训练基地,时间紧急,为尽快了解所有菜品,进行点菜,使用APP。

  • 用户场景B:小泊看了食堂的菜,觉得并不好吃,在APP中选择跳转至美团,即可进入美团界面,进行望梅止渴。


支付接口取消

技术图片

在经过实际调研之后,了解到想要把微信或者支付宝接口连接到我们的APP上,并不实际。微信和支付宝要求申请用户拥有三年的经营许可证方可通过,只好放弃

流程图的细节进行修改

技术图片

技术图片

代码规范及编码原则


程序风格:


  • 严格采用阶梯层次组织程序代码

  • 每层次缩进为4格,括号位于下一行。要求相匹配的大括号在同一列,对继行则要求再缩进4格

  • 提示信息字符串的位置 在程序中需要给出的提示字符串,为了支持多种语言的开发,除了一些给调试用的临时信息外,其他所有的提示信息必须定义在资源中。

  • 对变量的定义,尽量位于函数的开始位置。


命名规则


  • 变量名的命名规则;


  • 分析:变量名的命名规则遵循用户自定义标识符命名规则

    • 只能由字母、数字、下划线组成;

    • 第一个字符必须是英文字母;

    • 有效长度为255个字符;

    • 不可以包含标点符号和类型说明符%,&,!,# ,@,$;

    • 不可以是系统的关键词比如else



注释


  • 注释要简单明了。

  • 边写代码边注释,修改代码同时修改相应的注释,以保证 注释与代码的一致性。

  • 在必要的地方注释,注释量要适中。注释的内容要清楚,明了,含义准确,防止注释二义性。

  • 保持注释与其描述的代码相邻,即注释的就近原则。   

  • 对代码的注释应放在其上方相邻位置,不可放在下面。   

  • 对数据结构的注释应放在其上方相邻位置,不可放在下面;对结构中的每个域 的注释应放在此域的右方;

  • 同一结构中不同域的注释要对齐。

  • 变量、常量的注释应放在其上方相邻位置或右方。

  • 全局变量要有较详细的注释,包括对其功能、取值范围、哪些函数或过程存取它以及存取时注意事项等的说明。   

  • 在每个源文件的头部要有必要的注释信息,包括:文件名;版本号;作者;生成日期;

  • 模块功能描述(如功能、主要算法、内部各部分之间的关系、该文件与其它文件关系等);

  • 主要函数或过程清单及本文件历史修改记录等。

  • 在每个函数或过程的前面要有必要的注释信息,包括:函数或过程名称;功能描述;

  • 输入,输出及返回值说明;调用关系及被调用关系说明等。


可读性


  • 避免使用不易理解的数字,用有意义的标识来替代。   

  • 不要使用难懂的技巧性很高的语句。

  • 源程序中关系较为紧密的代码应尽可能相邻。


函数过程


  • 函数的规模尽量限制在200行以内。   

  • 一个函数最好仅完成一件功能。   

  • 为简单功能编写函数。   

  • 函数的功能应该是可以预测的,也就是只要输入数据相同就应产生同样的输出。   

  • 尽量不要编写依赖于其他函数内部实现的函数。

  • 避免设计多参数函数,不使用的参数从接口中去掉。   

  • 用注释详细说明每个参数的作用、取值范围及参数间的关系。   

  • 检查函数所有参数输入的有效性。

  • 检查函数所有非参数输入的有效性,如数据文件、公共变量等。

  • 函数名应准确描述函数的功能。

  • 避免使用无意义或含义不清的动词为函数命名

  • 函数的返回值要清楚、明了,让使用者不容易忽视错误情况。   

  • 明确函数功能,精确(而不是近似)地实现函数设计。   

  • 减少函数本身或函数间的递归调用。   

  • 编写 可重入函数时,若使用全局变量,则应通过关中断、信号量(即P、V操作)等手段对其加以保护。


变量编辑


  • 去掉没必要的公共变量。

  • 构造仅有一个模块或函数可以修改、创建,而其余有关模块或函数只访问的公共变量,防止多个不同模块或函数都可以修改、创建同一公共变量的现象。

  • 仔细定义并明确公共变量的含义、作用、取值范围及公共变量间的关系。

  • 明确公共变量与操作此公共变量的函数或过程的关系,如访问、修改及创建等。

  • 当向公共变量传递数据时,要十分小心,防止赋与不合理的值或越界等现象发生。

  • 防止局部变量与公共变量同名。

  • 仔细设计结构中元素的布局与排列顺序,使结构容易理解、节省占用空间,并减 少引起误用现象。

  • 结构的设计要尽量考虑 向前兼容和以后的版本升级,并为某些未来可能的应用保留余地(如预留一些空间等)。

  • 留心具体语言及编译器处理不同数据类型的原则及有关细节。   

  • 严禁使用未经初始化的变量。声明变量的同时对变量进行初始化。   

  • 编程时,要注意数据类型的 强制转换。


代码编译


  • 编写代码时要注意随时保存,并定期备份,防止由于断电、硬盘损坏等原因造成代码丢失。

  • 同一项目组内,最好使用相同的编辑器,并使用相同的设置选项。

  • 合理地设计软件系统目录,方便开发人员使用。

  • 打开编译器的所有告警开关对程序进行编译。

  • 在同一项目组或产品组中,要统一编译开关选项.

  • 使用工具软件对代码版本进行维护。


Powerdesigner数据库设计ER图


后端架构设计


推荐阅读
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 2018年3月31日,CSDN、火星财经联合中关村区块链产业联盟等机构举办的2018区块链技术及应用峰会(BTA)核心分会场圆满举行。多位业内顶尖专家深入探讨了区块链的核心技术原理及其在实际业务中的应用。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 自学编程与计算机专业背景者的差异分析
    本文探讨了自学编程者和计算机专业毕业生在技能、知识结构及职业发展上的不同之处,结合实际案例分析两者的优势与劣势。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • Google最新推出的嵌入AI技术的便携式相机Clips现已上架,旨在通过人工智能技术自动捕捉用户生活中值得纪念的时刻,帮助人们减少照片数量过多的问题。 ... [详细]
  • 本文深入探讨了计算机网络的基础概念和关键协议,帮助初学者掌握网络编程的必备知识。从网络结构到分层模型,再到传输层协议和IP地址分类,文章全面覆盖了网络编程的核心内容。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
author-avatar
凤凰花开清风自来_406
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有