美文网首页
命名规范

命名规范

作者: 不务正业的coder | 来源:发表于2018-05-11 15:41 被阅读0次

1 说明

为各种配置项、程序和工作产物命名,是一个非常重要的事情。为了便于沟通交流,在一个研发组织内部,都会形成命名的规范。本文档的目标就是约定和梳理本部门在研发中遇到的各种程序和产物的命名规则。

在整个文档中,会有一些对于标准和实践的推荐和建议。一些实践是非常重要的,必须严格执行,另一些指导准则并不一定处处适用,但是会在特定的场景下带来益处。为了清楚陈述规范和实践的意图,我们会使用如下术语。

<colgroup><col><col><col></colgroup>
| | | |
| | | |
| | |
| | | |
| | |
| | | |

2 通用约定

本章节的约定适用于以下所有章节:

  1. 一定要使用英文或者英文缩写。一定不要使用汉语拼音或者英文夹杂汉语拼音。
  2. 应该尽量使用英文全称,控制使用缩写。除非缩写是约定俗成,便于他人理解的;或者英文全称过长。一般在8个字符以内的单词,尽量不要使用缩写。

2.1 命名规则

常见命名规则有四种样式:完全大写、完全小写、Pascal 大小写和 Camel 大小写。本文后续章节所描述的类型中,将根据需要和惯例选择这四种中的一种。

2.1.1 Pascal 大小写

组成标识符的每个单词的首字母大写,其余字母小写的书写约定。对于缩写的双字母单词,要求全部大写。例如:ApplicationExceptionID 。

2.1.2 Camel 大小写

标识符的首字母小写,每个后面连接的单词的首字母大写,其余字母小写的书写约定。对于缩写的双字母单词,要求它们出现在标识符首部时全部小写,否则全部大写。例如:applicationException、 id 。

3 产品

产品编号由3-6位字符组成, 一般的命名分为两级,产品线-产品。对于部分产品,也可直接使用3位的唯一产品码,具体视实际情况零活掌握。

产品线使用3位字符命名,采用完全大写样式,产品线之下,可以根据需要定义产品,产品使用3位字符命名,采用完全大写样式。这样加上产品线的编码,形成6位字符的全称。为了方便阅读,可在产品线与子产品之间加上“-”符号。

例如统一运营平台之下有一个统一账户后台。则:

<colgroup><col><col><col><col></colgroup>
| | | | |
| | | | |

3.1 产品版本号

产品版本号的完整格式一定要遵循:{主版本}.{小版本号}.{修订版本号}.{构建号},全部采用数字的方式。例如1.0.0.1223001

在产品路线图规划,用户故事地图等,使用{主版本}.{小版本号},个别情况可细化到{修订版本号}。

3.2 文档

产品相关文档名称的格式为: {产品编号}_{文档用途}V{文档版本号}.{文件后缀}。

其中文档文档用途可为中文或英文。

文档版本号建议使用{主版本}.{小版本号}的格式

例如:

 UAP_产品需求说明书V1.0.docx

4 Restful接口

接口的完整名称格式一定要如下:

http(s)://{域名}/{平台}/{产品}/{version}/{模块}/{资源}

l Version:API的大版本号,建议使用V1,V2的格式;

l 模块:可选,根据产品的规模选用,建议完全小写或Camel 大小写。

l 资源:建议完全小写或Camel 大小写

4.1 HTTP Header

如果需要自定义报文头,应采取如下格式:

X-{产品}-{自定义内容}

产品名使用完全大写,自定义内容建议完全小写或Camel 大小写。

4.2 JSON

JSON数据的key值应该使用Camel 大小写,并且不要出现空格。

4.3 错误返回码

接口应结合HTTP状态码返回详细的错误码。

错误码格式为{平台}-{产品}-{5位数字错误码};

5 Java语言

Java语言建议遵从业界规范,以下是一些说明:

5.1 包(Packages)

使用全部小写样式,一定要按照组织.平台.子产品.模块的形式命名。

例如:com.wanda.uap.login

5.2 接口(Interfaces)

以大写字母”I”开头,后续使用Pascal 大小写。例如 IRasterDelegate。

6 数据库

**一、 **

6.1 Redis

Redis基于Key-Value的形式进行数据存储。对于key的命名,建议遵循如下规则:

l 按照product:object-type:id:field格式设计。

n Product:产品编号

n Object-type: 统一定义分配,基本上按照领域对象命名。建议使用Pascal 大小写和 Camel 大小写。

n Id: 一个Object-Type下的唯一主键。一般应包含业务对象主键,例如用户号、session ID等。

n Field: 为Object之下的字段,根据需要设置.

例如

缓存项:统一账户平台会员最后登录时间

Key = UAP:Account:123: LastLoginTime

Value = 2016-3-1 11:11:30,

由于Redis的key也是会占用内存空间的,因此建议不要使用太长的key.

6.2 关系数据库

6.2.1 表

表以”T_”开头。后面实际内容部分使用Pascal 大小写。

例如:T_PersonalMember

6.2.2 字段

字段使用Pascal 大小写。例如以下字段:

| | |
| | |
| | |
| | |
| | |
| | |

相关文章

  • 适合各厂使用的 MySQL 团队开发规范,太详细了,建议收藏!

    数据库对象命名规范 数据库对象 数据库对象全局命名规范 数据库命名规范 表命名规范 字段命名规范 索引命名规范 视...

  • 代码书写规范

    res命名规范: src中命名规范: 习惯命名:

  • Android开发中的优化方案

    一、命名规范 代码规范先从命名规范开始,Android的命名规范主要涉及:Java源代码,xml文件,图片资源。 ...

  • Swift--规范编程

    命名规范 注释规范 声明 代码排版 命名规范 常用命名方法 匈牙利命名,一般只是命名变量,原则是: 变量名 = 类...

  • Flutter 代码规范

    命名规范 命名规范中包括了文件以及文件夹的命名规范,常量和变量的命名规范,类的命令规范。Dart 中只包含这三种命...

  • 入门13 CSS综合

    CSS编码规范 命名规范:语义化标签优先;基于功能命名、基于内容命名、基于表现命名;简略、明了、无后患 书写规范:...

  • 规范文档

    1.命名规范2.注释规范3.代码规范4.目录规范 1.命名规范 通用规范通用规范是在整个项目中,所有的命名都需要遵...

  • 内部前端规范v1.0

    项目目录结构规范 请查看 项目目录结构规范 HTML 命名规范 class 命名实行 BEM命名方式。关于BEM,...

  • [知识点滴]Div+CSS命名规范大全

    Div+CSS命名规范(前端web开发命名规范)Div+CSS命名规范(一)窗体头:header内容:conten...

  • 2018-06-28 python命名规范

    Python命名规范 Google Python****命名规范 module_name, 模块 package...

网友评论

      本文标题:命名规范

      本文链接:https://www.haomeiwen.com/subject/jzifdftx.html