我认为,我理解“Bean”是一个具有财产和getters/setter的Java-class。据我所知,它相当于C结构。这是真的吗?

此外,JavaBean和常规类之间是否存在真正的语法差异?是否有特殊定义或接口?

基本上,为什么有一个术语?

Serializable接口是什么意思?


当前回答

要使Java类可用作Javabean,它的方法名需要符合JavaBeans针对财产、方法和事件的指导原则(也称为设计模式)。该类需要是公共类,才能被任何beanbox工具或容器访问。容器必须能够实例化它;当类为public时,即使没有提供显式的公共零参数构造函数,容器也应该能够这样做。(没有显式构造函数的Java公共类有一个默认的公共零参数构造函数。)因此,Java公共类,即使是属性作为唯一成员(当然,需要附带公共getter和setter)或公共方法作为唯一成员,也是Java bean。该属性可以是只读属性(它有getter方法,但没有setter)或只写属性(只有setter方法)。具有公共事件侦听器注册方法作为唯一成员的Java公共类也是Javabean。JavaBeans规范不要求如果这样的Java类具有显式公共构造函数,那么它应该是零参数的。如果可以提供包含序列化实例的文件(扩展名为.ser),beanbox工具可能可以使用该文件实例化原型bean。否则,类将需要一个构造函数,无论是显式的还是默认的,它是公共的,并且没有参数。

一旦bean被实例化,JavaBeans API(java.beans.*)就可以对其进行内省并在其上调用方法。如果没有实现接口BeanInfo或扩展BeanInfo实现的类(例如SimpleBeanInfo类)可用,自省包括使用反射(隐式自省)来研究目标bean支持的方法,然后应用简单的设计模式(指南)从这些方法中推断出支持哪些财产、事件和公共方法。如果实现接口BeanInfo(对于bean Foo,必须命名为FooBeanInfo)的类可用,则API将绕过隐式内省,并使用该类的公共方法(getPropertyDescriptor()、getMethodDescriptors()和getEventSetDescriptors(())来获取信息。如果一个扩展SimpleBeanInfo的类可用,取决于哪些SimpleBeanInfo公共方法(getPropertyDescriptor()、getMethodDescriptors()和getEventSetDescriptors(())被重写,它将使用这些被重写的方法获取信息;对于未被重写的方法,它将默认为相应的隐式内省。无论如何,bean都需要实例化,即使没有对其执行隐式内省。因此,需要公共零参数构造函数。但是,当然,Serializable或Externalizable接口不需要被识别。然而,JavaBeans规范表示,“我们也希望它对于一个只想保存其内部状态而不想考虑它的小Bean来说是“微不足道的”。”因此,所有Bean都必须实现Serializable或Externalizable接口。

总的来说,JavaBeans规范对bean的组成并不严格。“编写JavaBeans组件非常容易。你不需要特殊的工具,也不必实现任何接口。编写bean只是遵循某些编码约定。你所要做的就是让你的类看起来像一个bean——使用bean的工具将能够识别和使用你的bean。”,

公共类Trivial实现java.io.Serializable{}

目前为止的描述是JavaSE版本(JavaBeans)。如下所述,bean是JavaEE版本。这些版本建立在上述基本思想的基础上。特别是,他们考虑的一个主要思想是,如果bean构造函数确实有一些参数,该怎么办。这些参数可以是简单类型、类/接口类型或两者。应该有一种方法让容器知道在实例化bean时可以替换参数的值。这样做的方法是程序员可以通过注释或XML配置文件或两者的组合来配置(指定值)。

春豆

Spring bean在Spring IoC容器中运行。程序员可以通过XML配置文件、注释或两者的组合进行配置。

在Spring中,如果bean构造函数具有简单类型或类/接口类型参数,则可以以类型安全的方式将值分配为字符串(在前一种情况下作为构造函数参数元素的<value>属性,在后一种情况中作为构造函数参数的<idref>元素)。对其他Spring bean(称为协作者;通过构造函数参数元素中的<ref>元素)进行引用基本上是依赖注入,也是类型安全的。显然,依赖项(cooperatorbean)可能有一个带有注入参数的构造函数;这些注入的依赖项可能有一个带有参数等的构造函数。这个场景最终应该终止于注入的依赖关系,这些依赖关系是容器可以通过构造来实例化的原型bean。

JSF托管bean

JSF管理的bean在web容器中运行。可以使用@ManagedBean注释或应用程序配置资源文件managed-bean.xml来配置它们。JSF规范仅支持通过资源注入(而不是类型安全)进行注入。此注入不适合在构造函数上注入。在任何情况下,规范要求JSF托管bean必须具有公共零参数构造函数。此外,它还表示,“从本规范的2.3版开始,强烈使用本节中指定的托管bean工具沮丧。用于解决相同问题的更好且更紧密集成的解决方案是使用上下文和依赖注入(CDI),正如JSR-365中所规定的那样。“换句话说,应该使用CDI托管bean,它确实在类似于Spring bean的构造函数上提供了类型安全依赖注入。CDI规范采用了托管bean规范,它适用于JEE平台的所有容器,而不仅仅是web层。因此,web容器需要实现CDI规范。

托管Bean

以下是ManagedBean规范的摘录“ManagedBean是容器管理的对象,另外,也被称为缩写词“POJOs”(普通的旧Java对象)……它们可以被看作是JavaSE平台上JavaBeans组件模型的JavaEE平台增强版……读者不会错过,ManagedBeans在JavaServerFaces(JSF)技术中的同名功能中有一个先驱……本规范中定义的ManagedBean代表JSF中发现的那些的概括;特别是,ManagedBeans可以在JavaEE应用程序的任何地方使用,而不仅仅是在web模块中。例如,在基本组件模型中,ManagedBean必须提供无参数构造函数,但基于ManagedBean的规范(如CDI(JSR-299))可以放宽这一要求,并允许ManagedBean为构造函数提供更复杂的签名,只要它们遵循一些定义明确的规则。。。托管Bean不能是:最终类、抽象类或非静态内部类。与常规JavaBean组件不同,托管Bean可能不可序列化。“因此,ManagedBeans规范(也称为POJO或POJObeans)允许像CDI中那样进行扩展。

CDI豆类

CDI规范将托管bean重新定义为:在Java EE中运行时,如果顶级Java类满足以下要求,则它是托管bean:

•它不是内部类。•它是一个非抽象类,或者被注释为@Decorator。•它不实现javax.enterprise.inject.spi.Extension。•未标注@Vetoed或在标注为@Vetode的包中。•它有一个适当的构造函数,或者:该类有一个没有参数的构造函数,或该类声明了一个注释为@Inject的构造函数。

满足这些条件的所有Java类都是托管bean,因此没有特殊声明需要定义托管bean。或

如果任何其他Java EE规范,如果

•它没有使用EJB组件定义注释进行注释,也没有声明为EJB bean类在ejb-jar.xml中。

Bean构造函数可以有简单的类型参数,因为简单类型可以用@Inject注释注入。

EJBs

EJB在EJB容器中运行。EJB规范说:“会话bean组件是托管bean。”“类必须有一个不带参数的公共构造函数,”它对会话bean和消息驱动bean都这样说。此外,它还说:“不需要会话bean类来实现SessionBean接口或Serializable接口。”。“出于与JSFbean相同的原因,EJB3依赖注入基本上是资源注入,JSFbean不支持带参数的构造函数,即通过依赖注入。然而,如果EJB容器实现了CDI,“可选:类可能有一个附加的构造函数,用Inject注释注释,”它对会话bean和消息驱动bean都这样说,因为“打包到CDI bean存档中的EJB,没有用javax.enterprise.Inject.Vetoed注释注释,被认为是启用了CDI的bean。”

其他回答

要使Java类可用作Javabean,它的方法名需要符合JavaBeans针对财产、方法和事件的指导原则(也称为设计模式)。该类需要是公共类,才能被任何beanbox工具或容器访问。容器必须能够实例化它;当类为public时,即使没有提供显式的公共零参数构造函数,容器也应该能够这样做。(没有显式构造函数的Java公共类有一个默认的公共零参数构造函数。)因此,Java公共类,即使是属性作为唯一成员(当然,需要附带公共getter和setter)或公共方法作为唯一成员,也是Java bean。该属性可以是只读属性(它有getter方法,但没有setter)或只写属性(只有setter方法)。具有公共事件侦听器注册方法作为唯一成员的Java公共类也是Javabean。JavaBeans规范不要求如果这样的Java类具有显式公共构造函数,那么它应该是零参数的。如果可以提供包含序列化实例的文件(扩展名为.ser),beanbox工具可能可以使用该文件实例化原型bean。否则,类将需要一个构造函数,无论是显式的还是默认的,它是公共的,并且没有参数。

一旦bean被实例化,JavaBeans API(java.beans.*)就可以对其进行内省并在其上调用方法。如果没有实现接口BeanInfo或扩展BeanInfo实现的类(例如SimpleBeanInfo类)可用,自省包括使用反射(隐式自省)来研究目标bean支持的方法,然后应用简单的设计模式(指南)从这些方法中推断出支持哪些财产、事件和公共方法。如果实现接口BeanInfo(对于bean Foo,必须命名为FooBeanInfo)的类可用,则API将绕过隐式内省,并使用该类的公共方法(getPropertyDescriptor()、getMethodDescriptors()和getEventSetDescriptors(())来获取信息。如果一个扩展SimpleBeanInfo的类可用,取决于哪些SimpleBeanInfo公共方法(getPropertyDescriptor()、getMethodDescriptors()和getEventSetDescriptors(())被重写,它将使用这些被重写的方法获取信息;对于未被重写的方法,它将默认为相应的隐式内省。无论如何,bean都需要实例化,即使没有对其执行隐式内省。因此,需要公共零参数构造函数。但是,当然,Serializable或Externalizable接口不需要被识别。然而,JavaBeans规范表示,“我们也希望它对于一个只想保存其内部状态而不想考虑它的小Bean来说是“微不足道的”。”因此,所有Bean都必须实现Serializable或Externalizable接口。

总的来说,JavaBeans规范对bean的组成并不严格。“编写JavaBeans组件非常容易。你不需要特殊的工具,也不必实现任何接口。编写bean只是遵循某些编码约定。你所要做的就是让你的类看起来像一个bean——使用bean的工具将能够识别和使用你的bean。”,

公共类Trivial实现java.io.Serializable{}

目前为止的描述是JavaSE版本(JavaBeans)。如下所述,bean是JavaEE版本。这些版本建立在上述基本思想的基础上。特别是,他们考虑的一个主要思想是,如果bean构造函数确实有一些参数,该怎么办。这些参数可以是简单类型、类/接口类型或两者。应该有一种方法让容器知道在实例化bean时可以替换参数的值。这样做的方法是程序员可以通过注释或XML配置文件或两者的组合来配置(指定值)。

春豆

Spring bean在Spring IoC容器中运行。程序员可以通过XML配置文件、注释或两者的组合进行配置。

在Spring中,如果bean构造函数具有简单类型或类/接口类型参数,则可以以类型安全的方式将值分配为字符串(在前一种情况下作为构造函数参数元素的<value>属性,在后一种情况中作为构造函数参数的<idref>元素)。对其他Spring bean(称为协作者;通过构造函数参数元素中的<ref>元素)进行引用基本上是依赖注入,也是类型安全的。显然,依赖项(cooperatorbean)可能有一个带有注入参数的构造函数;这些注入的依赖项可能有一个带有参数等的构造函数。这个场景最终应该终止于注入的依赖关系,这些依赖关系是容器可以通过构造来实例化的原型bean。

JSF托管bean

JSF管理的bean在web容器中运行。可以使用@ManagedBean注释或应用程序配置资源文件managed-bean.xml来配置它们。JSF规范仅支持通过资源注入(而不是类型安全)进行注入。此注入不适合在构造函数上注入。在任何情况下,规范要求JSF托管bean必须具有公共零参数构造函数。此外,它还表示,“从本规范的2.3版开始,强烈使用本节中指定的托管bean工具沮丧。用于解决相同问题的更好且更紧密集成的解决方案是使用上下文和依赖注入(CDI),正如JSR-365中所规定的那样。“换句话说,应该使用CDI托管bean,它确实在类似于Spring bean的构造函数上提供了类型安全依赖注入。CDI规范采用了托管bean规范,它适用于JEE平台的所有容器,而不仅仅是web层。因此,web容器需要实现CDI规范。

托管Bean

以下是ManagedBean规范的摘录“ManagedBean是容器管理的对象,另外,也被称为缩写词“POJOs”(普通的旧Java对象)……它们可以被看作是JavaSE平台上JavaBeans组件模型的JavaEE平台增强版……读者不会错过,ManagedBeans在JavaServerFaces(JSF)技术中的同名功能中有一个先驱……本规范中定义的ManagedBean代表JSF中发现的那些的概括;特别是,ManagedBeans可以在JavaEE应用程序的任何地方使用,而不仅仅是在web模块中。例如,在基本组件模型中,ManagedBean必须提供无参数构造函数,但基于ManagedBean的规范(如CDI(JSR-299))可以放宽这一要求,并允许ManagedBean为构造函数提供更复杂的签名,只要它们遵循一些定义明确的规则。。。托管Bean不能是:最终类、抽象类或非静态内部类。与常规JavaBean组件不同,托管Bean可能不可序列化。“因此,ManagedBeans规范(也称为POJO或POJObeans)允许像CDI中那样进行扩展。

CDI豆类

CDI规范将托管bean重新定义为:在Java EE中运行时,如果顶级Java类满足以下要求,则它是托管bean:

•它不是内部类。•它是一个非抽象类,或者被注释为@Decorator。•它不实现javax.enterprise.inject.spi.Extension。•未标注@Vetoed或在标注为@Vetode的包中。•它有一个适当的构造函数,或者:该类有一个没有参数的构造函数,或该类声明了一个注释为@Inject的构造函数。

满足这些条件的所有Java类都是托管bean,因此没有特殊声明需要定义托管bean。或

如果任何其他Java EE规范,如果

•它没有使用EJB组件定义注释进行注释,也没有声明为EJB bean类在ejb-jar.xml中。

Bean构造函数可以有简单的类型参数,因为简单类型可以用@Inject注释注入。

EJBs

EJB在EJB容器中运行。EJB规范说:“会话bean组件是托管bean。”“类必须有一个不带参数的公共构造函数,”它对会话bean和消息驱动bean都这样说。此外,它还说:“不需要会话bean类来实现SessionBean接口或Serializable接口。”。“出于与JSFbean相同的原因,EJB3依赖注入基本上是资源注入,JSFbean不支持带参数的构造函数,即通过依赖注入。然而,如果EJB容器实现了CDI,“可选:类可能有一个附加的构造函数,用Inject注释注释,”它对会话bean和消息驱动bean都这样说,因为“打包到CDI bean存档中的EJB,没有用javax.enterprise.Inject.Vetoed注释注释,被认为是启用了CDI的bean。”

有一个术语可以让它听起来很特别。现实远没有那么神秘。

基本上,一个“憨豆”:

是一个可串行化的对象(即,它实现java.io.serializable,并正确执行)具有“财产”,其getter和setter只是具有特定名称的方法(例如,getFoo()是“Foo”属性的getter),并且有一个公共的零参数构造函数(因此可以随意创建并通过设置其财产进行配置)。

至于Serializable:这只是一个“标记接口”(一个不声明任何函数的接口),它告诉Java实现类同意(并暗示它能够)“序列化”——一个将实例转换为字节流的过程。这些字节可以存储在文件中,通过网络连接等发送,并且具有足够的信息,允许JVM(至少是一个了解对象类型的JVM)稍后重建对象——可能在应用程序的不同实例中,甚至在整个其他机器上!

当然,为了做到这一点,班级必须遵守某些限制。其中最主要的是,所有实例字段必须要么是原始类型(int、bool等),要么是某些类的实例,也可以是可序列化的,要么标记为瞬时的,这样Java就不会试图包含它们。(这当然意味着瞬态字段将无法在流上运行。如果需要,具有瞬态字段的类应该准备好重新初始化它们。)

不能遵守这些限制的类不应该实现Serializable(而且,IIRC,Java编译器甚至不允许它这样做)

JavaBeans用于更少的代码和更多的工作方法。。。

JavaBeans在整个JavaEE中被用作运行时发现和访问的通用契约。例如,JavaServerPages(JSP)使用JavaBeans作为页面之间或servlet和JSP之间的数据传输对象。Java EE的JavaBeans激活框架使用Java Beans将对MIME数据类型的支持集成到Java EE中。Java EE管理API使用JavaBeans作为在Java EE环境中管理的资源插入的基础。

关于序列化:

在对象序列化中,对象可以表示为一个字节序列,其中包括对象的数据以及关于对象类型和存储在对象中的数据类型的信息。

序列化对象写入文件后,可以从文件中读取并反序列化,也就是说,可以使用表示对象及其数据的类型信息和字节在内存中重新创建对象。

Spring@Bean注释表示一个方法生成一个由Spring容器管理的Bean。

更多参考:https://www.concretepage.com/spring-5/spring-bean-annotation

举例说明。

1.导入java.io.Serializable

关于序列化,请参阅文档。

2.私人领域

字段应该是私有的,以防止外部类轻易修改这些字段。通常使用getter/setter方法,而不是直接访问这些字段。

3.施工人员

没有任何参数的公共构造函数。

4.吸气器/设置器

用于访问和修改私有字段的Getter和setter方法。

/** 1. import java.io.Serializable */
public class User implements java.io.Serializable {
    /** 2. private fields */
    private int id;
    private String name;

    /** 3. Constructor */
    public User() {
    }
    public User(int id, String name) {
        this.id = id;
        this.name = name;
    }

    /** 4. getter/setter */
    // getter
    public int getId() {
        return id;
    }
    public String getName() {
        return name;
    }
    // setter
    public void setId(int id) {
        this.id = id;
    }
    public void setName(String name) {
        this.name = name;
    }
}