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

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

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

团队博客第二周——DIG


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


服务人群的改变

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

修改应用场景


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

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


支付接口取消

技术图片

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

流程图的细节进行修改

技术图片

技术图片

代码规范及编码原则


程序风格:


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

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

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

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


命名规则


  • 变量名的命名规则;


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

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

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

    • 有效长度为255个字符;

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

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



注释


  • 注释要简单明了。

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

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

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

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

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

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

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

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

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

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

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

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

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


可读性


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

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

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


函数过程


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

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

  • 为简单功能编写函数。   

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

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

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

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

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

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

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

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

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

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

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

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


变量编辑


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

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

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

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

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

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

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

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

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

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

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


代码编译


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

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

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

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

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

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


Powerdesigner数据库设计ER图


后端架构设计


推荐阅读
  • 软件测试工程师,需要达到什么水平才能顺利拿到 20k+ 无压力?
    前言最近看到很多应届生晒offer,稍有名气点的公司给出的价格都是一年30多W或者月薪20几k,相比之下工作几年的自己薪资确实很寒酸.根据我自己找工作经历,二线城市一般小公司招聘 ... [详细]
  • Unit4博客&课程总结Unit4作业的架构设计本单元作业的设计我分为了三个模块处理:模型构建+预处理+任务函数,前两部分即为整个图的完整构建,第三部分即为实现题目要求的查询方法。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • php实现文件下载代码一例,
    php教程|php手册php,实现,文件下载,代码,一例,php,实现,文件下载,代码,一例,我们,需要,用到,header,函数,来,发送,php教程-php手册php实现文件下 ... [详细]
  • 出现_史上最大漏洞出现,你的安卓iPhone电脑都不安全了!
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了史上最大漏洞出现,你的安卓iPhone电脑都不安全了!相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • qt学习(六)数据库注册用户的实现方法
    本文介绍了在qt学习中实现数据库注册用户的方法,包括登录按钮按下后出现注册页面、账号可用性判断、密码格式判断、邮箱格式判断等步骤。具体实现过程包括UI设计、数据库的创建和各个模块调用数据内容。 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
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社区 版权所有