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

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

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

团队博客第二周——DIG


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


服务人群的改变

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

修改应用场景


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

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


支付接口取消

技术图片

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

流程图的细节进行修改

技术图片

技术图片

代码规范及编码原则


程序风格:


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

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

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

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


命名规则


  • 变量名的命名规则;


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

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

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

    • 有效长度为255个字符;

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

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



注释


  • 注释要简单明了。

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

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

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

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

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

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

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

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

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

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

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

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

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


可读性


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

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

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


函数过程


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

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

  • 为简单功能编写函数。   

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

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

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

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

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

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

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

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

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

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

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

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


变量编辑


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

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

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

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

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

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

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

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

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

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

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


代码编译


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

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

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

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

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

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


Powerdesigner数据库设计ER图


后端架构设计


推荐阅读
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文深入探讨了 Java 编程语言的基础,特别是其跨平台特性和 JVM 的工作原理。通过介绍 Java 的发展历史和生态系统,帮助初学者理解如何编写并运行第一个 Java 程序。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文详细介绍了Linux系统中init进程的作用及其启动过程,解释了运行级别的概念,并提供了调整服务启动顺序的具体步骤和实例。通过了解这些内容,用户可以更好地管理系统的启动流程和服务配置。 ... [详细]
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社区 版权所有