Alibaba开发规范_编程规约之命名风格

news2025/4/23 16:38:15

文章目录

    • 命名风格的基本原则
      • 1. 命名不能以下划线或美元符号开始或结束
      • 2. 严禁使用拼音与英文混合或直接使用中文
      • 3. 类名使用 UpperCamelCase 风格,但以下情形例外:DO / BO / DTO / VO / AO / PO / UID 等
      • 4. 方法名、参数名、成员变量、局部变量使用 lowerCamelCase 风格
      • 5. 常量命名全部大写,单词间用下划线隔开
      • 6. 抽象类命名使用 Abstract 或 Base 开头,异常类命名使用 Exception 结尾
      • 7. 数组类型与中括号紧挨相连
      • 8. POJO 类中布尔类型变量不要加 is 前缀
      • 9. 包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词
      • 10. 避免在子父类的成员变量之间或不同代码块的局部变量之间采用完全相同的命名
      • 11. 杜绝完全不规范的缩写
      • 12. 使用尽量完整的单词组合来表达其意
      • 13. 表示类型的名词放在词尾
      • 14. 命名时体现出设计模式
      • 15. 接口类中的方法和属性不要加任何修饰符号
      • 16. 接口和实现类的命名规则
      • 17. 枚举类名带上 Enum 后缀,枚举成员名称需要全大写
      • 18. 各层命名规约
    • 结语

在这里插入图片描述

命名风格的基本原则

1. 命名不能以下划线或美元符号开始或结束

反例:

_name = "John"
__name = "Doe"
$name = "Jane"
name_ = "Smith"
name$ = "Brown"
name__ = "Taylor"

解释: 虽然有些开源代码使用下划线开头,但这种风格在Python中通常表示内部变量。为了保持一致性,建议避免使用下划线或美元符号作为命名的开始或结束。

2. 严禁使用拼音与英文混合或直接使用中文

反例:

int DaZhePromotion = 10; // 打折
void getPingfenByName() { // 评分
    // ...
}

正例:

int discountPromotion = 10;
void getScoreByName() {
    // ...
}

解释: 使用正确的英文拼写和语法可以避免歧义,提高代码的可读性。


3. 类名使用 UpperCamelCase 风格,但以下情形例外:DO / BO / DTO / VO / AO / PO / UID 等

正例:

class UserDO {
    // ...
}
class XmlService {
    // ...
}

反例:

class userDo {
    // ...
}
class XMLService {
    // ...
}

解释: 类名应使用大驼峰命名法,但一些特定缩写(如DO、DTO、VO等)可以例外。

  • DO( Data Object):与数据库表结构一一对应,通过DAO层向上传输数据源对象。
  • DTO( Data Transfer Object):数据传输对象,Service或Manager向外传输的对象。
  • BO( Business Object):业务对象。 由Service层输出的封装业务逻辑的对象。
  • VO( View Object):显示层对象,通常是Web向模板渲染引擎层传输的对象。
  • AO (Application Object) :应用对象,在 Web 层与 Service 层之间抽象的复用对象模型,极为贴近展示层,复用度不高。
  • POJO 是 DO / DTO / BO / VO 的统称.

4. 方法名、参数名、成员变量、局部变量使用 lowerCamelCase 风格

正例:

void getHttpMessage() {
    int localValue = 10;
    // ...
}

解释: 方法名、参数名、成员变量和局部变量应使用小驼峰命名法。


5. 常量命名全部大写,单词间用下划线隔开

正例:

final int MAX_STOCK_COUNT = 1000;
final long CACHE_EXPIRED_TIME = 3600;

反例:

final int maxCount = 1000;
final long expiredTime = 3600;

解释: 常量命名应全部大写,单词间用下划线隔开,以提高可读性。


6. 抽象类命名使用 Abstract 或 Base 开头,异常类命名使用 Exception 结尾

正例:

abstract class AbstractUser {
    // ...
}
class UserNotFoundException extends Exception {
    // ...
}

解释: 抽象类和异常类的命名应遵循特定的命名规则,以便于识别。


7. 数组类型与中括号紧挨相连

正例:

int[] arrayDemo = new int[10];

反例:

int arrayDemo[] = new int[10];

解释: 数组类型应与中括号紧挨相连,以提高代码的可读性。


8. POJO 类中布尔类型变量不要加 is 前缀

反例:

class User {
    private boolean isDeleted;
    // getter and setter
}

正例:

class User {
    private boolean deleted;
    // getter and setter
}

解释: 布尔类型变量不加 is 前缀,以避免框架解析时出现序列化错误。


9. 包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词

正例:

package com.alibaba.ai.util;

解释: 包名应使用小写,点分隔符之间应有一个自然语义的英语单词。


10. 避免在子父类的成员变量之间或不同代码块的局部变量之间采用完全相同的命名

反例:

class ConfusingName {
    public int age;
    public void getData(String alibaba) {
        if (condition) {
            final int money = 531;
            // ...
        }
        for (int i = 0; i < 10; i++) {
            final int money = 615; // 与上面的 money 同名
            // ...
        }
    }
}

解释: 避免在子父类的成员变量之间或不同代码块的局部变量之间使用相同的命名,以提高代码的可读性。


11. 杜绝完全不规范的缩写

反例:

class AbsClass { // AbstractClass 的缩写
    // ...
}

正例:

class AbstractClass {
    // ...
}

解释: 避免使用不规范的缩写,以确保代码的可读性。


12. 使用尽量完整的单词组合来表达其意

正例:

class AtomicReferenceFieldUpdater {
    // ...
}

反例:

int a; // 随意命名

解释: 使用完整的单词组合可以提高代码的自解释性。


13. 表示类型的名词放在词尾

正例:

long startTime;
Queue<String> workQueue;
List<String> nameList;
int TERMINATED_THREAD_COUNT;

反例:

long startedAt;
Queue<String> QueueOfWork;
List<String> listName;
int COUNT_TERMINATED_THREAD;

解释: 表示类型的名词应放在词尾,以提高辨识度。


14. 命名时体现出设计模式

正例:

class OrderFactory {
    // ...
}
class LoginProxy {
    // ...
}
class ResourceObserver {
    // ...
}

解释: 在命名时体现出设计模式,有助于阅读者快速理解架构设计理念。


15. 接口类中的方法和属性不要加任何修饰符号

正例:

interface UserService {
    void commit();
    String COMPANY = "alibaba";
}

反例:

interface UserService {
    public abstract void f();
}

解释: 接口中的方法和属性应保持简洁,避免不必要的修饰符号。


16. 接口和实现类的命名规则

正例:

interface CacheService {
    // ...
}
class CacheServiceImpl implements CacheService {
    // ...
}

解释: 接口和实现类的命名应遵循特定的规则,以便于识别和理解。


17. 枚举类名带上 Enum 后缀,枚举成员名称需要全大写

正例:

enum ProcessStatusEnum {
    SUCCESS,
    UNKNOWN_REASON
}

解释: 枚举类名应带上 Enum 后缀,枚举成员名称应全大写。


18. 各层命名规约

A) Service/DAO 层方法命名规约

class UserService {
    User getUserById(int id) { // 获取单个对象
        // ...
    }
    List<User> listUsers() { // 获取多个对象
        // ...
    }
    int countUsers() { // 获取统计值
        // ...
    }
    void saveUser(User user) { // 插入
        // ...
    }
    void deleteUser(int id) { // 删除
        // ...
    }
    void updateUser(User user) { // 修改
        // ...
    }
}

B) 领域模型命名规约

class UserDO { // 数据对象
    // ...
}
class UserDTO { // 数据传输对象
    // ...
}
class UserVO { // 展示对象
    // ...
}

解释: 各层的命名应遵循特定的规约,以便于识别和理解。

结语

良好的命名风格是编写高质量代码的基础。通过遵循上述规约,开发者可以提高代码的可读性、可维护性和可扩展性。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2291243.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MATLAB中的IIR滤波器设计

在数字信号处理中&#xff0c;滤波器是消除噪声、提取特征或调整信号频率的核心工具。其中&#xff0c;无限脉冲响应&#xff08;IIR&#xff09;滤波器因其低阶数实现陡峭滚降的特性&#xff0c;被广泛应用于音频处理、通信系统和生物医学工程等领域。借助MATLAB强大的工具箱&…

vector容器(详解)

本文最后是模拟实现全部讲解&#xff0c;文章穿插有彩色字体&#xff0c;是我总结的技巧和关键 1.vector的介绍及使用 1.1 vector的介绍 https://cplusplus.com/reference/vector/vector/&#xff08;vector的介绍&#xff09; 了解 1. vector是表示可变大小数组的序列容器。…

python学opencv|读取图像(五十二)使用cv.matchTemplate()函数实现最佳图像匹配

【1】引言 前序学习了图像的常规读取和基本按位操作技巧&#xff0c;相关文章包括且不限于&#xff1a; python学opencv|读取图像-CSDN博客 python学opencv|读取图像&#xff08;四十九&#xff09;原理探究&#xff1a;使用cv2.bitwise()系列函数实现图像按位运算-CSDN博客…

【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能

近期在做跟毕业设计相关的数据后台管理系统&#xff0c;其中的列表项展示有图片展示&#xff0c;添加/编辑功能有文件上传。 “文件上传/删除”也是我们平时开发会遇到的一个功能&#xff0c;这里分享个人的实现过程&#xff0c;与大家交流谈论~ 一、准备工作 本次案例使用的…

使用真实 Elasticsearch 进行高级集成测试

作者&#xff1a;来自 Elastic Piotr Przybyl 掌握高级 Elasticsearch 集成测试&#xff1a;更快、更智能、更优化。 在上一篇关于集成测试的文章中&#xff0c;我们介绍了如何通过改变数据初始化策略来缩短依赖于真实 Elasticsearch 的集成测试的执行时间。在本期中&#xff0…

【R语言】函数

一、函数格式 如下所示&#xff1a; hello&#xff1a;函数名&#xff1b;function&#xff1a;定义的R对象是函数而不是其它变量&#xff1b;()&#xff1a;函数的输入参数&#xff0c;可以为空&#xff0c;也可以包含参数&#xff1b;{}&#xff1a;函数体&#xff0c;如果…

VSCode插件Live Server

简介&#xff1a;插件Live Server能够实现当我们在VSCode编辑器里修改 HTML、CSS 或者 JavaScript 文件时&#xff0c;它都能自动实时地刷新浏览器页面&#xff0c;让我们实时看到代码变化的效果。再也不用手动刷新浏览器了&#xff0c;节省了大量的开发过程耗时&#xff01; 1…

50. 正点原子官方系统镜像烧写实验

一、Windows下使用OTG烧写系统 1、在Windos使用NXP提供的mfgtool来向开发烧写系统。需要用先将开发板的USB_OTG接口连接到电脑上。 Mfgtool工具是向板子先下载一个Linux系统&#xff0c;然后通过这个系统来完成烧写工作。 切记&#xff01;使用OTG烧写的时候要先把SD卡拔出来&…

扩散模型(三)

相关阅读&#xff1a; 扩散模型&#xff08;一&#xff09; 扩散模型&#xff08;二&#xff09; Latent Variable Space 潜在扩散模型&#xff08;LDM&#xff1b;龙巴赫、布拉特曼等人&#xff0c;2022 年&#xff09;在潜在空间而非像素空间中运行扩散过程&#xff0c;这…

it基础使用--5---git远程仓库

it基础使用–5—git远程仓库 1. 按顺序看 -git基础使用–1–版本控制的基本概念 -git基础使用–2–gti的基本概念 -git基础使用–3—安装和基本使用 -git基础使用–4—git分支和使用 2. 什么是远程仓库 在第一篇文章中&#xff0c;我们已经讲过了远程仓库&#xff0c;每个本…

Baklib如何改变内容管理平台的未来推动创新与效率提升

内容概要 在信息爆炸的时代&#xff0c;内容管理平台成为了企业和个人不可或缺的工具。它通过高效组织、存储和发布内容&#xff0c;帮助用户有效地管理信息流。随着技术的发展&#xff0c;传统的内容管理平台逐渐暴露出灵活性不足、易用性差等局限性&#xff0c;这促使市场需…

16.[前端开发]Day16-HTML+CSS阶段练习(网易云音乐五)

完整代码 网易云-main-left-rank&#xff08;排行榜&#xff09; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name&q…

ARM嵌入式学习--第十天(UART)

--UART介绍 UART(Universal Asynchonous Receiver and Transmitter)通用异步接收器&#xff0c;是一种通用串行数据总线&#xff0c;用于异步通信。该总线双向通信&#xff0c;可以实现全双工传输和接收。在嵌入式设计中&#xff0c;UART用来与PC进行通信&#xff0c;包括与监控…

Unity游戏(Assault空对地打击)开发(3) 摄像机的控制

详细步骤 打开My Assets或者Package Manager。 选择Unity Registry。 搜索Cinemachine&#xff0c;找到 Cinemachine包&#xff0c;点击 Install按钮进行安装。 关闭窗口&#xff0c;新建一个FreeLook Camera&#xff0c;如下。 接着新建一个对象Pos&#xff0c;拖到Player下面…

【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)

目录 1 -> 生命周期 1.1 -> 应用生命周期 1.2 -> 页面生命周期 2 -> 资源限定与访问 2.1 -> 资源限定词 2.2 -> 资源限定词的命名要求 2.3 -> 限定词与设备状态的匹配规则 2.4 -> 引用JS模块内resources资源 3 -> 多语言支持 3.1 -> 定…

小程序-基础加强-自定义组件

前言 这次讲自定义组件 1. 准备今天要用到的项目 2. 初步创建并使用自定义组件 这样就成功在home中引入了test组件 在json中引用了这个组件才能用这个组件 现在我们来实现全局引用组件 在app.json这样使用就可以了 3. 自定义组件的样式 发现页面里面的文本和组件里面的文…

尝试ai生成figma设计

当听到用ai 自动生成figma设计时&#xff0c;不免好奇这个是如何实现的。在查阅了不少资料后&#xff0c;有了一些想法。参考了&#xff1a;在figma上使用脚本自动生成色谱 这篇文章提供的主要思路是&#xff1a;可以通过脚本的方式构建figma设计。如果我们使用ai 生成figma脚本…

【周易哲学】生辰八字入门讲解(八)

&#x1f60a;你好&#xff0c;我是小航&#xff0c;一个正在变秃、变强的文艺倾年。 &#x1f514;本文讲解【周易哲学】生辰八字入门讲解&#xff0c;期待与你一同探索、学习、进步&#xff0c;一起卷起来叭&#xff01; 目录 一、六亲女命六亲星六亲宫位相互关系 男命六亲星…

解决whisper 本地运行时GPU 利用率不高的问题

我在windows 环境下本地运行whisper 模型&#xff0c;使用的是nivdia RTX4070 显卡&#xff0c;结果发现GPU 的利用率只有2% 。使用 import torch print(torch.cuda.is_available()) 返回TRUE。表示我的cuda 是可用的。 最后在github 的下列网页上找到了问题 极低的 GPU 利…

【自开发工具介绍】SQLSERVER的ImpDp和ExpDp工具02

工具运行前的环境准备 1、登录用户管理员权限确认 工具使用的登录用户(-u后面的用户)&#xff0c;必须具有管理员的权限&#xff0c;因为需要读取系统表 例&#xff1a;Export.bat -s 10.48.111.12 -d db1 -u test -p test -schema dbo      2、Powershell的安全策略确认…