J2EE中各种对象让人眼花缭乱的专业缩略词

本文解析了Java开发中常见的对象角色,如PO、BO、VO、DTO及POJO的区别与联系,并探讨了它们在不同场景下的转换与应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在java的浑水里趟过的这几年,我觉得自己依然是个无知的菜鸟。J2EE开发中大量的专业缩略语很是让人眼花缭乱,尤其是跟一些高手讨论问题的时候,分分钟担心就被人家满口的专业术语淹没,POVO、 BO、 DTO 、POJO、 DAO……,一大堆的就像机关枪扫过来,在枪林弹雨中安静地战死了。听过老罗对这种现象的批判的朋友会会心一笑,我就吐槽到此吧,回归正传。

PO:persistant object 持久对象
可以看成是与数据库中的表相映射的java对象。最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何对数据库的操作。

BO:business object 业务对象
主要作用是把业务逻辑封装为一个对象,这个对象可以包括一个或多个其它的对象,封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。
比如一个简历,有教育经历、工作经历、社会关系等等,我们可以把教育经历对应一个PO,工作经历对应一个PO,社会关系对应一个PO。建立一个对应简历的BO对象处理简历,每个BO包含这些PO。这样处理业务逻辑时,我们就可以针对BO去处理。

VO :value object 值对象 || ViewObject 表现层对象
通常用于业务层之间的数据传递,对应界面显示的数据对象,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要。个人觉得类似于DTO(数据传输对象),在web上传递。对于一个WEB页面,或者SWT、SWING的一个界面,用一个VO对象对应整个界面的值。

DTO :Data Transfer Object数据传输对象
主要用于远程调用等需要大量传输对象的地方。
比如我们一张表有100个字段,那么对应的PO就有100个属性。但是我们界面上只要显示10个字段,客户端用WEB service来获取数据,没有必要把整个PO对象传递到客户端,这时我们就可以用只有这10个属性的DTO来传递结果到客户端,这样也不会暴露服务端表结构.到达客户端以后,如果用这个对象来对应界面显示,那此时它的身份就转为VO了!

POJO :plain ordinary java object 简单无规则java对象
POJO算是最常见最多变的对象,是一个中间对象,也是我们最常打交道的对象。

一个POJO持久化以后就是PO,直接用它传递、传递过程中就是DTO,直接用来对应表示层就是VO

POJO的定义还有另外一种更简洁的描述:
POJO:Pure Old Java Object,符合Java Bean属性规范的简单Java对象,通常也称为VO(Value Object,值对象)。

DAO:data access object 数据访问对象
这个大家最熟悉,主要用来封装对数据库的访问,和上面几个O区别最大,通常和PO结合使用,DAO中包含了各种数据库的操作方法。通过它的方法,结合PO对数据库进行相关的操作,基本没有互相转化的可能性和必要,通过它可以把POJO持久化为PO,用PO组装出来VO、DTO。

小结:

一个对象究竟是什么O要看具体环境,在不同的层、不同的应用场合,对象的身份也不一样,而且对象身份的转化也是很自然的。就像你对爸爸妈妈来说是儿子或女儿,对你的小宝贝来说就是爸爸妈妈。设计这些概念的初衷不是为了唬人而是为了更好的理解和处理各种逻辑,让大家能更好的用面向对象的方式处理问题,简化业务逻辑.
千万不要陷入过度设计,为了设计而设计一定要在代码中区分各个对象的话,会物极必反的。技术是为应用服务的,过分的执着与技术就像修炼武功走火入魔!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值