javax.inject中@Inject、@Named、@Qualifier和@Provider用法

@Inject

@Inject支持构造函数、方法和字段注解,也可能使用于静态实例成员。可注解成员可以是任意修饰符(private,package-private,protected,public)。注入顺序:构造函数、字段,然后是方法。父类的字段和方法注入优先于子类的字段和方法,同一类中的字段和方法是没有顺序的。

@Inject注解的构造函数可以是无参或多个参数的构造函数。@Inject每个类中最多注解一个构造函数。

在字段注解:

  • 用@Inject注解
  • 字段不能是final的
  • 拥有一个合法的名称

在方法上注解:

  • 用@Inject注解
  • 不能是抽象方法
  • 不能声明自身参数类型
  • 可以有返回结果
  • 拥有一个合法的名称
  • 可以有0个或多个参数

@Inject MethodModirers ResultType Identifier(FormalParameterList ) Throws MethodBody

[上述翻译:inject的doc文档,翻译不好敬请谅解]

构造函数注解:

[java] view plaincopy

  1. @Inject
  2. public House(Person owner) {
  3. System.out.println("---这是房屋构造函数---");
  4. this.owner = owner;
  5. }

字段注解:

[java] view plaincopy

  1. @Inject private Person owner;

方法注解:

[java] view plaincopy

  1. @Inject
  2. public void setOwner(Person owner) {
  3. this.owner = owner;
  4. }

@Inject注解和Spring的@Autoware注解都是根据类型对其进行自动装配。

SpringUtil类:

[java] view plaincopy

  1. public class SpringUtil {
  2. private static ApplicationContext context = null;
  3. public static ApplicationContext getApplicationContext() {
  4. if (context == null) {
  5. context = new ClassPathXmlApplicationContext("spring.xml");
  6. }
  7. return context;
  8. }
  9. public static ApplicationContext getApplicationContext(String path) {
  10. return new ClassPathXmlApplicationContext(path);
  11. }
  12. public static ApplicationContext getAnnotationConfigApplicationContext(String basePackages) {
  13. return new AnnotationConfigApplicationContext(basePackages);
  14. }
  15. }

Person类:

[java] view plaincopy

  1. import javax.inject.Named;
  2. @Named
  3. public class Person {
  4. private String name;
  5. public Person() {
  6. System.out.println("---这是人的构造函数---");
  7. }
  8. public String getName() {
  9. return name;
  10. }
  11. public void setName(String name) {
  12. this.name = name;
  13. }
  14. }

House类:

[java] view plaincopy

  1. @Named
  2. public class House {
  3. @Inject private Person owner;
  4. public House() {
  5. System.out.println("---这是房屋构造函数---");
  6. }
  7. public Person getOwner() {
  8. return owner;
  9. }
  10. public void setOwner(Person owner) {
  11. this.owner = owner;
  12. }
  13. }

测试类:

[java] view plaincopy

  1. public class Test {
  2. public static void main(String[] args) {
  3. ApplicationContext context = SpringUtil.getApplicationContext(
  4. "test/spring/inject/bean-inject.xml");
  5. House house = (House)context.getBean("house");
  6. Person p = house.getOwner();
  7. p.setName("张三");
  8. System.out.println(house.getOwner().getName());
  9. }
  10. }

输出结果:

---这是房屋构造函数---
---这是人的构造函数---
张三

上述例子在Spring3.1下测试成功,在Spring3.1下,每个构造函数只初始化一次及默认的单例形式,个人感觉如果脱离Spring环境应该每次用都会实例化新的对象,当然根据实现的jar包不同而不同,要不javax.inject下的@Singleton注解就没有什么用途了。

@Named

@Named和Spring的@Component功能相同。@Named可以有值,如果没有值生成的Bean名称默认和类名相同。

例如:

[java] view plaincopy

  1. @Named public class Person

该bean的名称就是person。

[java] view plaincopy

  1. @Named("p") public class Person

如果指定名称,那么就是指定的名称喽。

@Qualifier

任何人都可以定义一个新的修饰语,一个qualifier注解应该满足如下条件:

  • 定义的注解类有@Qualifier,@Retention(RUNTIME)和@Documented。
  • 可以有属性
  • 可以是公共API的一部分
  • 可以用@Target注解限定使用范围

下面是Qualifier的例子:

Genre注解类:

[java] view plaincopy

  1. @Documented
  2. @Retention(RetentionPolicy.RUNTIME)
  3. @Qualifier
  4. @Target(value = {ElementType.FIELD, ElementType.PARAMETER, ElementType.TYPE})
  5. public @interface Genre {
  6. User user() default User.STUDENT;
  7. public enum User {STUDENT, TEACHER}
  8. }

用户接口:(对个数进行统计)

[java] view plaincopy

  1. public interface IUserDAO {
  2. int count();
  3. }

StudentDAO:

[java] view plaincopy

  1. @Named
  2. @Genre(user = User.STUDENT)
  3. public class StudentDAO implements IUserDAO{
  4. @Override
  5. public int count() {
  6. System.out.println("----StudentDAO----");
  7. return 0;
  8. }
  9. }

TeacherDAO:

[java] view plaincopy

  1. @Named
  2. @Genre(user = User.TEACHER)
  3. public class TeacherDAO implements IUserDAO {
  4. @Override
  5. public int count() {
  6. System.out.println("--TeacherDAO--");
  7. return 0;
  8. }
  9. }

UserDAOProcessor:

[java] view plaincopy

  1. @Named
  2. public class UserDAOProcessor {
  3. /*对TeacherDAO类的注入,如果对StudentDAO类注入应该是:@Genre(user = User.STUDENT)或@Genre,因为@Genre默认的是STUDENT*/
  4. @Inject
  5. private @Genre(user = User.TEACHER) IUserDAO userDAO;
  6. public int count() {
  7. return userDAO.count();
  8. }
  9. public IUserDAO getUserDAO() {
  10. return userDAO;
  11. }
  12. public void setUserDAO(IUserDAO userDAO) {
  13. this.userDAO = userDAO;
  14. }
  15. }

测试类:

[java] view plaincopy

  1. public class Test {
  2. public static void main(String[] args) {
  3. ApplicationContext context = SpringUtil.getApplicationContext(
  4. "test/spring/inject/bean-inject.xml");
  5. UserDAOProcessor processor = (UserDAOProcessor)context.getBean("userDAOProcessor");
  6. System.out.println(processor.count());
  7. }
  8. }

输出结果:

--TeacherDAO--
0

个人对@Qualifier的理解:

  1. 和Spring的@Qualifier大致相同
  2. 单独用@Inject无法满足对接口的注入,无法找到哪个具体类,所以用@Qualifier来确定注入的具体类
  3. 用到@Qualifier的注解中可以有值、无值和用枚举类型

@Singleton

使用该注解标记该类只创建一次,不能被继承。一般在类上用该注解。

原文:http://blog.csdn.net/binxigogo/article/details/7851924

时间: 2024-12-05 19:34:10

javax.inject中@Inject、@Named、@Qualifier和@Provider用法的相关文章

AngularJS中serivce,factory,provider的区别

一.service引导 刚开始学习Angular的时候,经常被误解和被初学者问到的组件是 service(), factory(), 和 provide()这几个方法之间的差别.This is where we'll start the twenty-five days of Angular calendar. 二.service 在Angular里面,services作为单例对象在需要到的时候被创建,只有在应用生命周期结束的时候(关闭浏览器)才会被清除.而controllers在不需要的时候就

Spring中的注解 @Qualifier

在使用Spring框架中@Autowired标签时默认情况下使用 @Autowired 注释进行自动注入时,Spring 容器中匹配的候选 Bean 数目必须有且仅有一个.当找不到一个匹配的 Bean 时,Spring 容器将抛出 BeanCreationException 异常,并指出必须至少拥有一个匹配的 Bean. Spring 允许我们通过 @Qualifier 注释指定注入 Bean 的名称,这样歧义就消除了,可以通过下面的方法解决异常. @Qualifier("XXX")

Data Provider 中没有.net framework Data provider for Mysql 的解决方法

近来做的一个项目中,数据库用的是 MySql, 而在项目使用 Entity Data Model 来做数据服务层,可是在项目中添加 Data Entty Model 时,一般我们都会选择从数据库中直接生成,可是在选择Data Provider 时,就是没有 .net framework  Data provider for Mysql, 里面默认就只有一个 .net framework Data provider for SQL Server , 这个只能与 Microsoft 的 SQL se

HBase入门实例: Table中Family和Qualifier的关系与区别

Table中Family和Qualifier的关系与区别 就像用MySQL一样,我们要做的是表设计,MySQL中的表,行,列的在HBase已经有所区别了,在HBase中主要是Table和Family和Qualifier,这三个概念.Table可以直接理解为表,而Family和Qualifier其实都可以理解为列,一个Family下面可以有多个Qualifier,所以可以简单的理解为,HBase中的列是二级列,也就是说Family是第一级列,Qualifier是第二级列.两个是父子关系. 谈谈Ta

如何在ASP.NET Core中自定义Azure Storage File Provider

文章标题:如何在ASP.NET Core中自定义Azure Storage File Provider作者:Lamond Lu地址:https://www.cnblogs.com/lwqlun/p/10406566.html项目源代码: https://github.com/lamondlu/AzureFileProvider 背景# ASP.NET Core是一个扩展性非常高的框架,开发人员可以根据自己的需求扩展出想要的功能.File Provider是ASP.NET Core中的一个重要组件

js中获取时间new date()的用法

js中获取时间new date()的用法 获取时间:   var myDate = new Date();//获取系统当前时间 获取特定格式的时间: 1 myDate.getYear(); //获取当前年份(2位) 2 myDate.getFullYear(); //获取完整的年份(4位,1970-????) 3 myDate.getMonth(); //获取当前月份(0-11,0代表1月) 4 myDate.getDate(); //获取当前日(1-31) 5 myDate.getDay();

sphinx中复合属性字段sql_attr_multi的用法

sphinx中复合属性字段sql_attr_multi的用法 sql_attr_multi在sphinx可以用来检索有层级关系的数据,效率相当高,如,在数据库中用一个4层的分类,分类下对应着不用的文章,现在需要做一个文章列表,要求,选择第一级分类时属于它的子分类的文章也要显示出来,就可以用下面的方法建索引 sql_query=                 SELECT di.company_document_id as id,di.company_document_id,          

Android中资源文件中的字符串数组string-array简单用法

在Android中,用string-array是一种简单的提取XML资源文件数据的方法. 例子如下: 把相应的数据放到values文件夹的strings.xml文件里,或是其他自定义的xml中都可以,以下操作方法相同. <?xml version="1.0" encoding="utf-8"?> <resources> <string-array name="sports"> <item>足球<

CSS中伪类及伪元素用法详解

原文:CSS中伪类及伪元素用法详解 伪类的分类及作用: 注:该表引自W3School教程 伪元素的分类及作用: 接下来让博主通过一些生动的实例(之前的作业或小作品)来说明几种常用伪类的用法和效果,其他的读者可以自己尝试: :active  大致效果为用鼠标点击时,元素增加特效,鼠标松开时,特效消失.多用在按钮的点击上. 写法: 这里id为box的是一div块,在css中首先设置了他的基本样式,下面为加入:active伪类后需要修改的样式. 未点击时: 点击之后: :active.:hover.: