0

0

在Java中如何设计一个合理的类_Java类设计规范解析

P粉602998670

P粉602998670

发布时间:2026-02-07 02:43:17

|

235人浏览过

|

来源于php中文网

原创

Java类命名须大驼峰且与文件名严格一致;包名全小写;字段优先private final;构造函数禁业务逻辑,用构造器注入;方法遵循单一职责,参数少而语义清。

在java中如何设计一个合理的类_java类设计规范解析

类名必须用大驼峰,且与文件名严格一致

Java编译器强制要求 public 类的名称必须和文件名完全相同(包括大小写),否则编译失败。比如定义了 public class HttpClientUtil,就必须保存在 HttpClientUtil.java 中;若误写成 httpclientutil.javaHttpClientutil.javajavac 会报错 class HttpClientUtil is public, should be declared in a file named HttpClientUtil.java

public 类可以和文件名不一致,但不建议——这会让团队成员难以定位类,IDE 也无法正确索引。

  • 包名全小写(如 com.example.order),避免下划线或大写字母
  • 类名体现职责,避免模糊词如 ManagerHelperTool(除非确实只做单一工具方法)
  • 接口名也用大驼峰,通常以形容词或名词结尾(如 RunnableOrderRepository),避免加 I 前缀(那是 C# 风格)

字段优先私有 + final,暴露用 getter 而非 public 字段

直接暴露 public 字段会破坏封装,导致外部随意修改、无法添加校验逻辑、难以调试变更来源。哪怕只是 public static final String VERSION = "1.2" 这种常量,也建议统一用 public static final + 大写下划线命名,且确保不可变。

实例字段几乎都该是 private,需要读取时提供 getXXX() 方法;如果字段本身是可变对象(如 ListMap),getter 必须返回副本(如 new ArrayList(this.items)),否则外部仍能修改内部状态。

立即学习Java免费学习笔记(深入)”;

  • private final 是首选组合:明确表达“初始化后不变”,JVM 也能更好优化
  • 布尔字段不要用 isXXX() 命名却返回非布尔值,否则 Jackson、Spring 等框架反射解析会出错
  • 避免为每个字段机械生成 getter/setter:只暴露真正需要被外部访问的属性

构造函数只做必要初始化,拒绝业务逻辑和远程调用

构造函数里执行 HTTP 请求、数据库查询、文件读取等操作,会导致 new 对象失败风险高、单元测试难 mock、类生命周期失控。例如 new OrderService() 内部去连 Redis,那所有单元测试都会因网络失败而挂掉。

艺帆网络工作室网站源码1.7.5
艺帆网络工作室网站源码1.7.5

艺帆网络工作室网站源码,是国庆后新一批新概念的网站源码,采用流行的Html5和JS组合流畅顺滑,界面清晰明朗,适合科技类企业和公司建站使用。如果你是想成为一家独特的设计公司,拥有独特的文化,追求品质,而非数量与规模。 这种坚持一直贯穿于项目运作之中,从品牌建立、形象推广设计到品牌形象管理。那可以考虑使用这款艺帆网络工作室网站源码。 这款源码中服务项目和团队程序需要在_template文件夹下的in

下载

合理做法是把依赖通过构造参数注入(即“构造器注入”),让创建者负责提供已准备好的协作对象:

public class OrderService {
    private final OrderRepository repository;
    private final NotificationClient notifier;
public OrderService(OrderRepository repository, NotificationClient notifier) {
    this.repository = Objects.requireNonNull(repository);
    this.notifier = Objects.requireNonNull(notifier);
}

}

  • 所有非 primitive / 不可变类型的参数,建议用 Objects.requireNonNull() 校验,及早暴露空指针
  • 避免重载过多构造函数,优先用 Builder 模式处理可选参数多的场景
  • 不要在构造函数中调用 this.xxx() 非 final 方法——子类可能覆盖它,而此时子类字段还未初始化

方法设计遵循单一职责,参数尽量少且语义清晰

一个方法超过 10 行、参数超过 4 个、方法名含 “and” 或 “or”,基本说明它在承担多个职责。比如 processAndNotifyAndLog(Order order, boolean sendEmail) 就该拆成 process(order)notify(order)log(order) 三个方法。

参数类型优先用具体契约而非宽泛类型:用 Instant 而非 Date,用 List 而非 Collection(除非真要兼容 Set/Queue),用 Path 而非 String 表示路径。

  • 避免布尔参数控制行为分支(如 save(order, true))——改用两个方法 saveWithValidation()saveWithoutValidation()
  • 返回值别用 null 表示“无结果”,优先用 Optional(但仅限于可能为空的查找场景;集合返回空 ListOptional 更自然)
  • 异常策略要明确:检查型异常(Exception)用于可预期且调用方应恢复的错误(如文件不存在);运行时异常(RuntimeException)用于编程错误或不可恢复问题(如参数为 null)

类设计最易被忽略的其实是“何时不该设计新类”——比如只是为了把几个静态方法包在一起而建一个 StringUtils,没问题;但若开始往里塞状态、依赖、构造逻辑,就该立刻停下来问:它到底是一个实体?一个服务?还是本该是某个现有类的方法?

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

118

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

72

2026.01.26

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

606

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

354

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

34

2025.11.30

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

240

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

600

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1513

2023.10.24

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.3万人学习

C# 教程
C# 教程

共94课时 | 8.7万人学习

Java 教程
Java 教程

共578课时 | 59万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号