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

概述

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

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

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


编程规约 - 命名风格 P15

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

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

java 复制代码
正例

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

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

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


编程规约 - 命名风格 P16

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

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

public abstract void f(); // 接口方法定义 
  • 说明:JDK8 中接口允许有默认实现,那么这个 default 方法,是对所有实现类都有价值的默认实现。
2、学习补充
  1. 在 Java 接口中定义的变量默认是 public static final 的,其实就是一个常量
java 复制代码
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 开始,接口中可以包含默认方法

java 复制代码
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 开始,接口中可以包含静态方法
java 复制代码
interface MyStaticInterface {
    static void staticMethod() {
        System.out.println("这是静态方法");
    }
}

MyStaticInterface.staticMethod();
  1. 接口定义并结合有效的 Javadoc 注释
java 复制代码
/**
 * 用户服务接口,定义了与用户相关的操作。
 */
    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";
}
相关推荐
清辞8534 分钟前
入门大模型工程师第十课----学习总结
大数据·人工智能·深度学习·学习·语言模型
caimouse11 分钟前
ReactOS 部分编译指南
开发语言
Chase_______14 分钟前
【Java基础 | 13】IO 流(下):缓冲流、转换流、序列化与综合案例
java·开发语言
弹简特15 分钟前
【零基础学Python-收尾】10-Python第三方库的安装介绍
开发语言·python
弗锐土豆28 分钟前
自动化-程序员从抽象与具象的角度学习自动化
学习·程序员·自动化·抽象·具象
雪度娃娃29 分钟前
ASIO异步通信——多线程模型
开发语言·网络·c++·php
bush432 分钟前
嵌入式linux学习记录十二,mmap
java·linux·学习
luj_176835 分钟前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法
源码宝36 分钟前
基于SpringCloud+UniApp的智慧工地云平台整体架构设计与实现
java·人工智能·spring cloud·源码·智慧工地·云平台
Lucky_云佳42 分钟前
ArcMap-去除底图水印
经验分享·arcgis·arcmap·google earth