news 2026/6/9 14:19:47

SpringBoot中的命名与开发规范

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot中的命名与开发规范

SpringBoot中的命名与开发规范

在 Spring Boot 项目开发中,Java 类的命名(如BOPOVODTO)通常是根据其在项目中的角色和职责来确定的。平时开发项目,经常对于这些类名的命名有疑惑,所以记录下来。这些命名约定有助于提高代码的可读性和可维护性。以下是每种类型的定义、使用场景和命名建议:


1. PO (Persistent Object)

定义

  • PO 是持久化对象,通常与数据库表一一对应,用于表示数据库中的一条记录。

使用场景

  • 用于与数据库交互的实体类。
  • 通常与 ORM 框架(如 JPA、MyBatis)一起使用。

命名建议

  • 类名通常与数据库表名对应,例如:
@Entity @Table(name = "user") public class UserPO { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; private String email; // Getters and Setters }

2. DTO (Data Transfer Object)

定义

  • DTO 是数据传输对象,用于在不同层(如 Controller 层和 Service 层)之间传递数据。
  • DTO 通常只包含数据字段,不包含业务逻辑。

使用场景

  • 用于封装 API 请求或响应的数据。
  • 用于减少网络传输的数据量(例如,只传递需要的字段)。

命名建议

  • 类名通常以DTO结尾,例如:
public class UserDTO { private Long id; private String name; private String email; // Getters and Setters }

3. VO (Value Object)

定义

  • VO 是值对象,用于表示一个不可变的对象,通常用于封装一组相关的数据。
  • VO 通常是不可变的(即字段为final),并且没有业务逻辑。

使用场景

  • 用于表示一个复杂的值,例如日期范围、坐标等。
  • 用于封装一组相关的数据,便于传递和使用。

命名建议

  • 类名通常以VO结尾,例如:
public class AddressVO { private final String city; private final String street; private final String zipCode; public AddressVO(String city, String street, String zipCode) { this.city = city; this.street = street; this.zipCode = zipCode; } // Getters }

4. BO (Business Object)

定义

  • BO 是业务对象,用于封装业务逻辑和数据。
  • BO 通常包含业务方法和数据字段。

使用场景

  • 用于封装复杂的业务逻辑。
  • 用于表示一个业务实体,例如订单、用户等。

命名建议

  • 类名通常以BO结尾,例如:
public class OrderBO { private Long id; private List<OrderItem> items; private BigDecimal totalAmount; public BigDecimal calculateTotalAmount() { // Business logic to calculate total amount return items.stream() .map(OrderItem::getAmount) .reduce(BigDecimal.ZERO, BigDecimal::add); } // Getters and Setters }

5. 其他常见对象

(1) Entity

  • 与 PO 类似,但更强调与数据库的映射关系。
  • 通常用于 JPA 实体类。

(2) Model

  • 用于表示一个通用的数据模型,通常用于 MVC 模式中的 Model 层。

(3) Form

  • 用于封装表单数据,通常用于前端提交的数据。

6. 如何确定使用哪种对象?

(1) 根据职责划分

  • PO:与数据库表对应,用于持久化数据。
  • DTO:用于层与层之间的数据传输。
  • VO:用于表示一个不可变的值对象。
  • BO:用于封装业务逻辑和数据。

(2) 根据使用场景

  • 如果对象需要与数据库交互,使用PO
  • 如果对象用于 API 请求或响应,使用DTO
  • 如果对象表示一个复杂的值,使用VO
  • 如果对象包含业务逻辑,使用BO

(3) 根据项目规范

  • 遵循团队或项目的命名规范。
  • 保持一致性,避免混用不同类型的对象。

7. 示例:完整的分层结构

以下是一个典型的分层结构示例:

Controller 层

@RestController @RequestMapping("/users") public class UserController { @Autowired private UserService userService; @PostMapping public ResponseEntity<UserDTO> createUser(@RequestBody UserDTO userDTO) { UserDTO createdUser = userService.createUser(userDTO); return ResponseEntity.ok(createdUser); } }

Service 层

@Service public class UserService { @Autowired private UserRepository userRepository; public UserDTO createUser(UserDTO userDTO) { UserPO userPO = convertToPO(userDTO); userRepository.save(userPO); return convertToDTO(userPO); } private UserPO convertToPO(UserDTO userDTO) { // Conversion logic } private UserDTO convertToDTO(UserPO userPO) { // Conversion logic } }

Repository 层

@Repository public interface UserRepository extends JpaRepository<UserPO, Long> { }

PO 类

@Entity @Table(name = "user") public class UserPO { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; private String email; // Getters and Setters }

DTO 类

public class UserDTO { private Long id; private String name; private String email; // Getters and Setters }

总结

  • PO:与数据库表对应,用于持久化数据。
  • DTO:用于层与层之间的数据传输。
  • VO:用于表示一个不可变的值对象。
  • BO:用于封装业务逻辑和数据。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 16:02:15

Docker Buildx多架构构建难题破解(Agent镜像优化实战手册)

第一章&#xff1a;Docker Buildx多架构构建的核心挑战在跨平台应用部署日益普及的背景下&#xff0c;Docker Buildx 为开发者提供了原生支持多架构镜像构建的能力。然而&#xff0c;在实际使用中&#xff0c;多架构构建仍面临诸多技术挑战&#xff0c;涉及性能、兼容性与配置复…

作者头像 李华
网站建设 2026/6/8 14:38:49

跨网文件安全交换系统排名解析,中大型企业复杂场景适配指南

随着数字化转型深入&#xff0c;企业为保护核心数据&#xff08;如研发图纸、客户隐私、业务报表&#xff09;&#xff0c;普遍采用网络隔离策略&#xff0c;将内部网络划分为研发网、办公网、生产网等不同安全域。但网络隔离与数据交换需求的矛盾日益突出&#xff0c;传统传输…

作者头像 李华
网站建设 2026/6/8 22:52:16

Sa-Token OAuth2.0 安全认证框架深度解析

Sa-Token OAuth2.0 安全认证框架深度解析 【免费下载链接】Sa-Token 一个轻量级 java 权限认证框架&#xff0c;让鉴权变得简单、优雅&#xff01; —— 登录认证、权限认证、分布式Session会话、微服务网关鉴权、SSO 单点登录、OAuth2.0 统一认证 项目地址: https://gitcode…

作者头像 李华
网站建设 2026/6/8 12:02:32

SageAttention终极指南:如何通过量化注意力实现3倍推理加速

SageAttention终极指南&#xff1a;如何通过量化注意力实现3倍推理加速 【免费下载链接】SageAttention Quantized Attention that achieves speedups of 2.1-3.1x and 2.7-5.1x compared to FlashAttention2 and xformers, respectively, without lossing end-to-end metrics …

作者头像 李华
网站建设 2026/6/8 19:56:58

Inno Setup中文界面配置:从零到精通的完整指南

Inno Setup中文界面配置&#xff1a;从零到精通的完整指南 【免费下载链接】Inno-Setup-Chinese-Simplified-Translation :earth_asia: Inno Setup Chinese Simplified Translation 项目地址: https://gitcode.com/gh_mirrors/in/Inno-Setup-Chinese-Simplified-Translation …

作者头像 李华
网站建设 2026/6/8 6:32:02

数据科学快速入门终极指南:从零认知到实战精通

数据科学快速入门终极指南&#xff1a;从零认知到实战精通 【免费下载链接】Data-Science-45min-Intros Ipython notebook presentations for getting starting with basic programming, statistics and machine learning techniques 项目地址: https://gitcode.com/gh_mirro…

作者头像 李华