0

0

在Java中如何定义一个标准的类结构_Java类设计规范解析

P粉602998670

P粉602998670

发布时间:2026-01-21 14:14:02

|

907人浏览过

|

来源于php中文网

原创

Java类名须用PascalCase且与文件名严格一致;字段默认private,配校验型getter/setter;构造方法需覆盖无参及全参场景;equals/hashCode/toString须成对重写并遵循规范。

在java中如何定义一个标准的类结构_java类设计规范解析

类名必须用 PascalCase 且匹配文件名

Java 要求 public 类的名称必须与文件名完全一致,且首字母大写的驼峰命名(PascalCase)。如果类声明为 public 但文件名是 userdao.javaUserDaoImpl.java,编译器会直接报错:class UserDao is public, should be declared in a file named UserDao.java

常见错误包括:

  • 类名用了下划线(user_dao)或全小写(userdao
  • 文件保存为 UTF-8 with BOM,导致编译器读取到不可见字符
  • 在 IDE 中重命名类但未同步改文件名(尤其 IntelliJ 默认不联动)

成员变量优先使用 private + getter/setter

标准 Java 类中,所有字段应默认声明为 private,不暴露内部状态。需要外部访问时,按需提供符合 JavaBeans 规范的 getXXX() / setXXX() 方法(布尔类型可用 isXXX())。

注意点:

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

Chromox
Chromox

Chromox是一款领先的AI在线生成平台,专为喜欢AI生成技术的爱好者制作的多种图像、视频生成方式的内容型工具平台。

下载
  • setter 应校验参数(如非空、范围),避免对象进入非法状态
  • 返回集合字段时,getter 不要直接返回内部引用,应返回副本(如 new ArrayList(this.items))或不可变包装(Collections.unmodifiableList(this.items)
  • 不要为只读字段提供 setter;也不要为常量(static final)生成 getter(除非有特殊封装逻辑)
public class User {
    private String name;
    private int age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        if (name == null || name.trim().isEmpty()) {
            throw new IllegalArgumentException("name cannot be null or empty");
        }
        this.name = name.trim();
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        if (age < 0 || age > 150) {
            throw new IllegalArgumentException("age must be between 0 and 150");
        }
        this.age = age;
    }
}

构造方法应覆盖常用初始化场景

一个“标准”的 Java 类通常至少提供一个无参构造方法(方便反射、序列化、框架如 Spring 使用),以及一个全字段构造方法(便于测试和明确依赖)。若字段较多,可考虑使用 Builder 模式,但不要在基础实体类里强行套用。

关键原则:

  • 避免在构造方法中调用可被子类重写的方法(可能引发 NullPointerException,因子类字段尚未初始化)
  • 构造方法内不做耗时操作(如 I/O、网络请求),这违背单一职责,也影响对象创建性能
  • 若类不可继承,显式加 final 修饰类;若部分方法不应被重写,用 final 修饰对应方法

重写 equals/hashCode/toString 需严格遵循约定

只要类会被放入 HashSetHashMap 或用于断言比较(如 JUnit 的 assertEquals),就必须正确重写 equals()hashCode()。IDE 自动生成的版本基本可用,但要注意:

  • 只基于「业务上认为相等」的字段参与比较(例如 User 类通常比对 id,而非 nameage
  • 若用 Lombok,确保 @EqualsAndHashCode 明确指定了 includeexclude 字段,否则默认包含所有非静态非瞬态字段,易出错
  • toString() 应简洁可读,推荐用 Objects.toStringHelper(Guava)或 String.format,避免拼接大量字段影响日志性能

最容易被忽略的是:一旦重写了 equals(),就必须重写 hashCode(),否则违反契约,HashMap 查找会失效。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

156

2025.08.06

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

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

88

2026.01.26

软件测试常用工具
软件测试常用工具

软件测试常用工具有Selenium、JUnit、Appium、JMeter、LoadRunner、Postman、TestNG、LoadUI、SoapUI、Cucumber和Robot Framework等等。测试人员可以根据具体的测试需求和技术栈选择适合的工具,提高测试效率和准确性 。

463

2023.10.13

java测试工具有哪些
java测试工具有哪些

java测试工具有JUnit、TestNG、Mockito、Selenium、Apache JMeter和Cucumber。php还给大家带来了java有关的教程,欢迎大家前来学习阅读,希望对大家能有所帮助。

313

2023.10.23

Java 单元测试
Java 单元测试

本专题聚焦 Java 在软件测试与持续集成流程中的实战应用,系统讲解 JUnit 单元测试框架、Mock 数据、集成测试、代码覆盖率分析、Maven 测试配置、CI/CD 流水线搭建(Jenkins、GitHub Actions)等关键内容。通过实战案例(如企业级项目自动化测试、持续交付流程搭建),帮助学习者掌握 Java 项目质量保障与自动化交付的完整体系。

30

2025.10.24

guava包作用
guava包作用

guava是一个java库,增强了java标准库,提供更有效率和易于使用的集合、实用程序、缓存和并发工具。想了解更多guava的相关内容,可以阅读本专题下面的文章。

271

2024.05.29

string转int
string转int

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

1030

2023.08.02

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

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

1567

2023.10.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.2万人学习

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

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