【发布时间】:2010-11-26 12:39:19
【问题描述】:
我不确定区别。我正在使用 Hibernate,并且在某些书籍中,它们使用 JavaBean 和 POJO 作为可互换的术语。我想知道是否存在差异,不仅仅是在 Hibernate 上下文中,而是作为一般概念。
【问题讨论】:
标签: java terminology pojo
我不确定区别。我正在使用 Hibernate,并且在某些书籍中,它们使用 JavaBean 和 POJO 作为可互换的术语。我想知道是否存在差异,不仅仅是在 Hibernate 上下文中,而是作为一般概念。
【问题讨论】:
标签: java terminology pojo
POJO 没有属性或方法的命名约定。我们不遵循任何实际的构造、访问和修改类状态的约定。
例子:
public class Pojo {
public String firstname;
public String LASTName;
public String name() {
return this.firstname + " " + this.LASTName;
}
}
在这里,我可以将firstname 替换为first_name 或Firstname 或任何noun,并且与变量LASTName 相同。
该术语很可能已获得广泛接受,因为 需要一个通用且易于理解的术语,与 复杂的对象框架。[2]
它可能会限制框架偏向于约定而不是配置、了解如何使用类以及增强其功能的能力。[1]
List<String> propertyNames =
Arrays.stream(PropertyUtils.getPropertyDescriptors(Pojo.class))
.map(PropertyDescriptor::getDisplayName)
.collect(Collectors.toList());
System.out.println(propertyNames);
如果我们使用第三方库 PropertyUtils 进行反思,我们可能会遇到问题,因为这会导致
[]
JavaBean 仍然是 POJO,但引入了一组严格的规则 我们如何实现它:
- 访问级别 - 我们的属性是私有的,我们公开了 getter 和 setter。
- 方法名称——我们的 getter 和 setter 遵循 getX 和 setX 约定(在布尔值的情况下,isX 可用于 吸气剂)
- 默认构造函数 - 必须是无参数构造函数 存在,因此可以在不提供参数的情况下创建实例,因为 反序列化过程中的示例
- Serializable - 实现 Serializable 接口允许我们存储状态。
例子:
@Getter
@Setter
class Pojo implements Serializable {
public String firstName;
public String lastName;
}
[firstName,lastName]
【讨论】:
综上所述:异同为:
java beans: Pojo:
-must extends serializable -no need to extends or implement.
or externalizable.
-must have public class . - must have public class
-must have private instance variables. -can have any access specifier variables.
-must have public setter and getter method. - may or may not have setter or getter method.
-must have no-arg constructor. - can have constructor with agruments.
所有 JAVA Bean 都是 POJO,但并非所有 POJO 都是 JAVA Bean。
【讨论】:
您已经看到了上面的正式定义,尽管它们很有价值。
但不要太拘泥于定义。 让我们更多地了解这里的意义。
JavaBeans 用于企业 Java 应用程序,其中用户经常远程访问数据和/或应用程序代码,即通过网络从服务器(通过 Web 或专用网络)访问。因此,所涉及的数据必须以串行格式流入或流出用户的计算机——因此需要 Java EE 对象来实现接口 Serializable。 JavaBean 的大部分性质与从文件系统读取或写入数据的 Java SE 应用程序对象没有什么不同。 通过网络从一系列用户机器/操作系统组合中可靠地使用 Java 类还需要采用约定来处理它们。因此,需要将这些类实现为公共的、具有私有属性、无参数构造函数以及标准化的 getter 和 setter。
Java EE 应用程序还将使用那些作为 JavaBean 实现的类以外的类。这些可用于处理输入数据或组织输出数据,但不会用于通过网络传输的对象。因此,上述考虑不需要应用于它们,除非它们作为 Java 对象有效。后面的这些类称为 POJO - 普通旧 Java 对象。
总而言之,您可以将 Java Bean 视为适合通过网络使用的 Java 对象。
自 1995 年以来,软件世界中出现了大量的炒作——而且不乏骗局。
【讨论】:
所有 JavaBean 都是 POJO,但并非所有 POJO 都是 JavaBean。
JavaBean 是满足某些编程约定的 Java 对象:
【讨论】:
Serializable。
Pojo - 普通的旧 java 对象
pojo 类是一个没有任何特殊性的普通类,类与技术/框架完全松散耦合。该类不从技术/框架实现,也不从技术/框架 api 扩展,该类称为 pojo 类。
pojo 类可以实现接口和扩展类,但超类或接口不应该是技术/框架。
例子:
1.
class ABC{
----
}
ABC 类没有实现或从技术/框架扩展,这就是为什么这是 pojo 类。
2.
class ABC extends HttpServlet{
---
}
ABC 类从 servlet 技术 api 扩展,这就是为什么这不是 pojo 类。
3.
class ABC implements java.rmi.Remote{
----
}
ABC 类从 rmi api 实现,这就是为什么这不是 pojo 类。
4.
class ABC implements java.io.Serializable{
---
}
这个接口是java语言的一部分而不是技术/框架的一部分。所以这是pojo类。
5.
class ABC extends Thread{
--
}
这里的线程也是java语言的类所以这也是一个pojo类。
6.
class ABC extends Test{
--
}
如果 Test 类从技术/框架扩展或实现,那么 ABC 也不是 pojo 类,因为它继承了 Test 类的属性。 如果 Test 类不是 pojo 类,那么 ABC 类也不是 pojo 类。
7.
现在这点是个例外
@Entity
class ABC{
--
}
@Entity 是 hibernate api 或 jpa api 给出的注解,但我们仍然可以将这个类称为 pojo 类。
在这种特殊情况下,具有从技术/框架给出的注释的类称为 pojo 类。
【讨论】:
POJO:如果该类可以使用底层JDK执行,而没有任何其他外部第三方库支持,则称为POJO
JavaBean:如果类仅包含带有访问器(setter 和 getter)的属性,则称为 javabean。Java bean 通常不包含任何业务逻辑,而是用于在其中保存一些数据。
所有 Javabean 都是 POJO,但所有 POJO 都不是 Javabean
【讨论】:
JavaBean 遵循某些约定。 Getter/setter 命名、具有公共默认构造函数、可序列化等。有关详细信息,请参阅JavaBeans Conventions。
POJO(plain-old-Java-object)没有严格定义。它是一个 Java 对象,不需要实现特定接口或从特定基类派生,或使用特定注释以与给定框架兼容,并且可以是任意的(通常相对简单) Java 对象。
【讨论】:
POJOS 具有某些约定(getter/setter、public no-arg 构造函数、私有变量)并且正在运行(例如,用于按表单读取数据)是JAVABEANS。
【讨论】:
根据 Martin Fowler 的说法,POJO 是一个封装业务逻辑的对象,而 Bean(除了在其他答案中已经说明的定义)只不过是一个用于保存数据的容器,对象上可用的操作只是设置和获取数据。
这个词是在 Rebecca Parsons、Josh MacKenzie 和我当时创造的 准备在 2000 年 9 月的一次会议上发表演讲。在演讲中,我们 指出将业务逻辑编码成 常规的 java 对象,而不是使用实体 Bean。我们想知道为什么 人们非常反对在他们的系统中使用常规对象,并且 得出的结论是,这是因为简单的对象缺乏花哨的名称。所以 我们给了他们一个,它很受欢迎。
【讨论】: