概述
-
《Java 开发手册》是阿里巴巴集团技术团队的集体智慧结晶和经验总结,他旨在提升开发效率和代码质量
-
《Java 开发手册》是一本极具价值的 Java 开发规范指南,对于提升开发者的综合素质和代码质量具有重要意义
-
学习《Java 开发手册》是一个提升 Java 编程技能、了解行业最佳实践和规范的好方法
编程规约 - 命名风格 P15
1、基本介绍
-
【推荐】如果模块、接口、类、方法使用了设计模式,在命名时需体现出具体模式。
-
说明:将设计模式体现在名字中,有利于阅读者快速理解架构设计理念。
正例public class OrderFactory;
public class LoginProxy;
public class ResourceObserver;
2、学习补充
-
OrderFactory:表明这个类是一个工厂类,负责创建订单对象。工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。
-
LoginProxy:表明这个类是一个代理类,用于处理登录操作。代理模式是一种结构型设计模式,它为一个对象提供一个占位符,以控制对这个对象的访问。
-
ResourceObserver:表明这个类是一个观察者,用于观察资源的变化。观察者模式是一种行为型设计模式,它定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态发生变化时,会通知所有观察者对象。
编程规约 - 命名风格 P16
1、基本介绍
- 【推荐】接口类中的方法和属性不要加任何修饰符号(public 也不要加),保持代码的简洁性,并加上有效的 Javadoc 注释。尽量不要在接口里定义变量,如果一定要定义变量,确定与接口方法相关,并且是整个应用的基础常量。
// 正例void commit(); // 接口方法签名
String COMPANY = "alibaba"; // 接口基础常量
// 反例public abstract void f(); // 接口方法定义
- 说明:JDK8 中接口允许有默认实现,那么这个 default 方法,是对所有实现类都有价值的默认实现。
2、学习补充
- 在 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";
-
在 Java 接口中定义的方法默认是
public abstract
的 -
从 Java8 开始,接口中可以包含默认方法
interface MyDefaultInterface {default void defaultMethod() {System.out.println("这是默认方法");}void abstractMethod();
}class MyClass implements MyDefaultInterface {@Overridepublic void abstractMethod() {System.out.println("实现抽象方法");}
}MyClass myClass = new MyClass();
myClass.defaultMethod();
myClass.abstractMethod();
- 从 Java8 开始,接口中可以包含静态方法
interface MyStaticInterface {static void staticMethod() {System.out.println("这是静态方法");}
}MyStaticInterface.staticMethod();
- 接口定义并结合有效的 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";
}