news 2026/6/23 1:32:41

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/23 7:50:33

Vue 3 + TypeScript 严格模式下的 Performance.now() 实践:构建高性能前端应用

在 Vue 3 的响应式系统与 Composition API 加持下&#xff0c;结合 TypeScript 严格模式的类型安全特性&#xff0c;我们可以构建出既精确又健壮的浏览器性能监控体系。本文将深入探讨在 Vue 3 生态中使用 performance.now() 的典型场景与最佳实践。 一、严格模式与 Vue 3 的完…

作者头像 李华
网站建设 2026/6/23 21:27:08

小红书破百的Blog

赛道&#xff1a;前端&#xff0c;学院本放弃Java赛道 考研 nnu GIS 01方向 —————— Offer&#xff1a; 快手&#xff1a;40W 京东总包比快手多一点&#xff08;去向&#xff09; 收钱吧&#xff1a;不到25w 泡池子&#xff08;面试通过&#xff0c;综合评估&#xff09;&…

作者头像 李华
网站建设 2026/6/23 21:28:22

OpenPose人体姿态估计:从零开始掌握5大核心功能

OpenPose人体姿态估计&#xff1a;从零开始掌握5大核心功能 【免费下载链接】openpose 项目地址: https://gitcode.com/gh_mirrors/op/openpose OpenPose作为业界领先的开源人体姿态估计库&#xff0c;能够实时检测图像或视频中的人体关键点&#xff0c;包括身体、面部…

作者头像 李华
网站建设 2026/6/18 15:58:20

51CTO学堂-Oracle RAC+DG生产实战(4):Oracle21c RAC DataGuard搭建2+2

Oracle 21c RACDG 实战&#xff1a;22 架构搭建全流程与生产环境高可用配置指南在数字化转型浪潮中&#xff0c;企业数据的高可用性和容灾能力已成为核心竞争力。Oracle 21c RAC&#xff08;Real Application Clusters&#xff09;与DG&#xff08;Data Guard&#xff09;的“2…

作者头像 李华
网站建设 2026/6/23 20:28:09

探索Lenia:发现连续细胞自动机中的数学生命奇迹

探索Lenia&#xff1a;发现连续细胞自动机中的数学生命奇迹 【免费下载链接】Lenia Lenia - Mathematical Life Forms 项目地址: https://gitcode.com/gh_mirrors/le/Lenia 你是否曾想象过数学公式能够孕育出拥有自主行为、复杂形态和演化能力的"生命"&#x…

作者头像 李华
网站建设 2026/6/23 21:24:11

2025网络安全学习路线,非常详细!推荐学习

关键词&#xff1a;网络安全入门、渗透测试学习、零基础学安全、网络安全学习路线 目录 学习的问题 1、打基础时间太长2、知识点掌握程度不清楚3、知识点分不清重点4、知识点学习不系统5、自己解决问题难6、实战水平不够7、内网学习困难较大 学习正确方向 方法 1 &#xff08;…

作者头像 李华