0

0

在Java里如何设计一个实体类_Java实体类编写规范说明

P粉602998670

P粉602998670

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

|

302人浏览过

|

来源于php中文网

原创

实体类必须实现Serializable并显式定义serialVersionUID,字段全用包装类型,提供无参和全参构造器,getter/setter严格遵循JavaBeans规范。

在java里如何设计一个实体类_java实体类编写规范说明

实体类必须实现 Serializable 且显式定义 serialVersionUID

不加 serialVersionUID 看似能编译通过,但一旦类结构变动(比如增减字段、改访问修饰符),反序列化会直接抛 InvalidClassException。JVM 自动生成的 UID 依赖编译器实现和类细节,不可控。

实操建议:

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

  • 用 IDE 自动生成(IntelliJ 快捷键 Alt+Enter → “Add serialVersionUID”)
  • 值推荐用 1L 或时间戳(如 20240501L),避免用随机数——便于版本追踪
  • 如果确定永不序列化(如纯 DTO 传给前端),可不加,但需团队明确约定并文档化

字段全部用 private,且禁止使用基本类型(int/boolean 等)

用基本类型会导致 null 值无法表达语义(例如数据库中 is_deletedNULLboolean deleted 只能是 false),也违反 ORM 框架(如 MyBatis、Hibernate)对可空字段的映射要求。

实操建议:

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

  • 对应数据库 TINYINT(1)BIT 的布尔字段,用 Boolean 而非 boolean
  • 数值类统一用包装类:IntegerLongBigDecimal(金额必用)
  • 字符串一律用 String,不用 char[] 或自定义字符容器

构造方法只保留无参 + 全参(或 Builder),禁用带参但漏字段的构造器

漏字段的构造器(比如只传 idname,忽略 createTime)会让对象处于不完整状态,后续被误用时难以排查(尤其在链式调用或 JSON 反序列化后)。

Tome
Tome

先进的AI智能PPT制作工具

下载

实操建议:

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

  • 必须提供无参构造器——MyBatis/JSON 库依赖它实例化对象
  • 全参构造器参数顺序应与字段声明顺序一致,降低阅读成本
  • 字段超 4 个时,优先用静态内部 Builder 类,避免长参数列表;避免 Lombok 的 @AllArgsConstructor 自动生成(易失控)

getter/setter 命名严格遵循 JavaBeans 规范,且避免在 setter 中做业务逻辑

setUserName(String name) 写成 setUser_name(String name)changeUserName(String name),会导致 Jackson、MyBatis 等框架无法识别属性,静默失败或映射为空。

实操建议:

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

  • 布尔字段 getter 必须是 isXxx()(如 isActive()),不能是 getXxx();否则 Jackson 默认不识别
  • setter 里只做赋值和简单校验(如 Objects.requireNonNull(name)),禁止触发远程调用、DB 查询、发消息等
  • 若需计算字段(如 getFullName()),不要加 @JsonIgnore 就完事,而应在类设计阶段判断:它是真实属性?还是视图层逻辑?后者应移出实体类
public class User implements Serializable {
    private static final long serialVersionUID = 20240501L;

    private Long id;
    private String username;
    private String email;
    private Boolean isActive;
    private BigDecimal balance;
    private LocalDateTime createTime;

    public User() {}

    public User(Long id, String username, String email, Boolean isActive, BigDecimal balance, LocalDateTime createTime) {
        this.id = id;
        this.username = username;
        this.email = email;
        this.isActive = isActive;
        this.balance = balance;
        this.createTime = createTime;
    }

    // getter/setter 略(按规范生成)
}
字段可空性、序列化行为、ORM 映射规则,这三者稍有错位,运行时就可能表现异常——不是报错,而是数据“悄悄消失”或“默认值覆盖”。写实体类不是堆字段,而是定义契约。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

547

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

hibernate和mybatis有哪些区别
hibernate和mybatis有哪些区别

hibernate和mybatis的区别:1、实现方式;2、性能;3、对象管理的对比;4、缓存机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

Hibernate框架介绍
Hibernate框架介绍

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

94

2025.08.06

Java Hibernate框架
Java Hibernate框架

本专题聚焦 Java 主流 ORM 框架 Hibernate 的学习与应用,系统讲解对象关系映射、实体类与表映射、HQL 查询、事务管理、缓存机制与性能优化。通过电商平台、企业管理系统和博客项目等实战案例,帮助学员掌握 Hibernate 在持久层开发中的核心技能。

39

2025.09.02

Hibernate框架搭建
Hibernate框架搭建

本专题整合了Hibernate框架用法,阅读专题下面的文章了解更多详细内容。

72

2025.10.14

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.3万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.1万人学习

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

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