Spring @Autowired 注解
-
@Autowired注解
@Autowired注解提供了在哪里以及如何自动装配应做到更精细的控制。@Autowired注解可用于在setter方法上自动装配bean,就像@Required注解,构造函数,具有任意名称和/或多个参数的属性或方法一样。 -
setter方法上@Autowired注解实例
您可以在setter方法上使用@Autowired注解,以摆脱XML配置文件中的<property>元素。当Spring找到与setter方法一起使用的@Autowired注解时,它将尝试对该方法执行byType自动装配。假设我们拥有一个运行良好的Eclipse IDE,并采取以下步骤来创建一个Spring应用程序:- 创建一个名称为SpringExample的项目,并在创建的项目的src文件夹下创建一个包com.jc2182
- 使用“添加外部JAR”选项添加所需的Spring库,如“Spring Hello World示例”一章中所述。
- 在com.jc2182包下创建Java类TextEditor, SpellChecker 和 MainApp。
- 在src文件夹下创建Beans配置文件Beans.xml。
- 最后一步是创建所有Java文件和Bean配置文件的内容,然后按以下说明运行应用程序。
以下是TextEditor.java内容。以下是另一个依赖类文件 SpellChecker.java的内容:以下是MainApp.java文件的内容。以下是配置文件的beans.xml它可以对基于setter方法注入配置创建完源和Bean配置文件后,让我们运行该应用程序。如果您的应用程序一切正常,这将打印以下消息: -
属性上@Autowired注解实例
您可以在属性上使用@Autowired注解,以摆脱setter方法。当您使用<property>传递自动装配属性的值时,Spring会自动为这些属性分配传递的值或引用。因此,在属性上使用@Autowired时,您的TextEditor.java文件将如下所示以下是配置文件创建完源和Bean配置文件后,让我们运行该应用程序。如果您的应用程序一切正常,这将打印以下消息: -
构造函数上@Autowired注解实例
您也可以将@Autowired应用于构造函数。构造函数@Autowired注解指示,即使在XML文件中配置Bean时不使用任何&l;tconstructor-arg>元素,也应在创建Bean时自动构造该构造函数。让我们检查以下示例。这是TextEditor.java文件的内容以下是配置文件创建完源和Bean配置文件后,让我们运行该应用程序。如果您的应用程序一切正常,这将打印以下消息: -
@Autowired(required = false)选项
默认情况下,@Autowired注解表示与@Required注解类似,需要依赖项,但是,可以通过对@Autowired 使用(required = false)选项来关闭默认行为。即使您没有为age属性传递任何值,但仍然需要name属性,下面的示例仍然有效。您可以自己尝试该示例,因为除了只更改了Student.java文件之外,它与@Required注释示例相似。