当前位置: 首页 > article >正文

学习嵩山版《Java 开发手册》:编程规约 - 命名风格(P15 ~ P16)

概述

  1. 《Java 开发手册》是阿里巴巴集团技术团队的集体智慧结晶和经验总结,他旨在提升开发效率和代码质量

  2. 《Java 开发手册》是一本极具价值的 Java 开发规范指南,对于提升开发者的综合素质和代码质量具有重要意义

  3. 学习《Java 开发手册》是一个提升 Java 编程技能、了解行业最佳实践和规范的好方法


编程规约 - 命名风格 P15

1、基本介绍
  • 【推荐】如果模块、接口、类、方法使用了设计模式,在命名时需体现出具体模式。

  • 说明:将设计模式体现在名字中,有利于阅读者快速理解架构设计理念。

正例

public class OrderFactory;
public class LoginProxy;
public class ResourceObserver;
2、学习补充
  1. OrderFactory:表明这个类是一个工厂类,负责创建订单对象。工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。

  2. LoginProxy:表明这个类是一个代理类,用于处理登录操作。代理模式是一种结构型设计模式,它为一个对象提供一个占位符,以控制对这个对象的访问。

  3. ResourceObserver:表明这个类是一个观察者,用于观察资源的变化。观察者模式是一种行为型设计模式,它定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态发生变化时,会通知所有观察者对象。


编程规约 - 命名风格 P16

1、基本介绍
  • 【推荐】接口类中的方法和属性不要加任何修饰符号(public 也不要加),保持代码的简洁性,并加上有效的 Javadoc 注释。尽量不要在接口里定义变量,如果一定要定义变量,确定与接口方法相关,并且是整个应用的基础常量。
// 正例

void commit(); // 接口方法签名
String COMPANY = "alibaba"; // 接口基础常量
// 反例

public abstract void f(); // 接口方法定义 
  • 说明:JDK8 中接口允许有默认实现,那么这个 default 方法,是对所有实现类都有价值的默认实现。
2、学习补充
  1. 在 Java 接口中定义的变量默认是 public static final 的,其实就是一个常量
interface UserService {

    // 表示用户的默认状态
    String DEFAULT_USER_STATUS = "ACTIVE";
}

System.out.println(UserService.DEFAULT_USER_STATUS);

// 如下代码会编译错误
// java: 无法为最终变量DEFAULT_USER_STATUS分配值
// UserService.DEFAULT_USER_STATUS = "UNKNOWN";
  1. 在 Java 接口中定义的方法默认是 public abstract

  2. 从 Java8 开始,接口中可以包含默认方法

interface MyDefaultInterface {
    default void defaultMethod() {
        System.out.println("这是默认方法");
    }

    void abstractMethod();
}

class MyClass implements MyDefaultInterface {
    @Override
    public void abstractMethod() {
        System.out.println("实现抽象方法");
    }
}

MyClass myClass = new MyClass();
myClass.defaultMethod();
myClass.abstractMethod();
  1. 从 Java8 开始,接口中可以包含静态方法
interface MyStaticInterface {
    static void staticMethod() {
        System.out.println("这是静态方法");
    }
}

MyStaticInterface.staticMethod();
  1. 接口定义并结合有效的 Javadoc 注释
/**
 * 用户服务接口,定义了与用户相关的操作。
 */
    interface UserService {

    /**
     * 创建一个新用户。
     *
     * @param username 用户名
     * @param password 密码
     * @return 创建的用户对象
     */
    User createUser(String username, String password);

    /**
     * 根据用户名查找用户。
     *
     * @param username 用户名
     * @return 查找到的用户对象,如果未找到则返回 null
     */
    User findUserByUsername(String username);

    /**
     * 用户服务接口的基础常量,表示用户的默认状态。
     */
    String DEFAULT_USER_STATUS = "ACTIVE";
}

http://www.kler.cn/a/421398.html

相关文章:

  • NLP 的研究任务
  • burp2
  • JAVA中HashMap、TreeMap、LinkedHashMap 的用法与注意事项
  • Android笔记【12】脚手架Scaffold和导航Navigation
  • java将word docx pdf转换为图片(不需要额外下载压缩包,直接导入maven坐标)
  • Android矩阵Matrix在1张宽平大Bitmap批量绘制N个小Bitmap,Kotlin(1)
  • Python HttpServer 的一个bug问题
  • The First项目报告:以太坊再质押赛道新星Swell Network
  • 2024年12月chrome131版本http自动跳转https解决
  • 【Unity基础】使用InputSystem实现物体跳跃
  • Zotero安装使用在线翻译Ubuntu
  • 数字运动_光影射箭(-->合作)
  • Vue前端页面内嵌套本项目iframe窗口的通信传输方式
  • 【深度学习|特征增强融合模块】MAF (Multi-scale Attention Fusion)一种多尺度的注意力融合模块
  • 原型模式的理解和实践
  • 小迪安全第四十二天笔记 简单的mysql注入 mysql的基础知识 用户管理数据库模式 mysql 写入与读取 跨库查询
  • 《从0到1常用Map集合核心摘要 + 不深不浅底层核心》
  • 网络安全内容整理二
  • Java基础面试题12:Java中的两种异常类型是什么?它们有什么区别?
  • AttributeError: ‘DataFrame‘ object has no attribute ‘append‘的参考解决方法
  • Linux67 绑定网卡【bonding和team】
  • 技术速递|Java on Azure Tooling 10月更新 - Azure 函数托管身份支持,Java on Azure 工具指南推出
  • Swift 宏(Macro)入门趣谈(五)
  • 【Anaconda】Anaconda3 下载与安装教程(Ubuntu 22.04)
  • SQL语法——DDL
  • 一键生成后端服务,MemFire Cloud重新定义开发效率