带有@Inject注解的类 使用 injector.getInstance初始化

http://blog.csdn.net/java_le/article/details/24851251

Google Guice 注入(@Inject注解)

原创 2014年05月01日 22:52:16
  • 3816

上一节介绍通过注解来实现绑定关系,这一节介绍如何通过@Inject来完成依赖注入的功能:

(1)属性注入

(2)构造方法注入

(3)setter方法注入

一.属性注入

(1)创建一个接口Hello.java和一个实现类HelloImpl

  1. package guice.di;
  2. import com.google.inject.ImplementedBy;
  3. //将这个接口和实现类HelloImpl绑定到一起
  4. @ImplementedBy(HelloImpl.class)
  5. public interface Hello {
  6. void sayHello() ;
  7. }
  8. package guice.di;
  9. //这里没有加@Singleton,表示是动态创建这个类,不是单例的
  10. public class HelloImpl implements Hello{
  11. @Override
  12. public void sayHello() {
  13. System.out.println("HelloImpl Say Hello");
  14. }
  15. }

通过@ImplementedBy注解,将接口和实现类绑定在一起

(2)创建一个HelloCaller(包含一个Hello属性)

  1. package guice.di;
  2. import com.google.inject.Inject;
  3. //HelloCaller将会去调用Hello这个接口提供的服务
  4. public class HelloCaller {
  5. //通过@Inject,来完成属性的注入
  6. @Inject
  7. private Hello hello ;
  8. //调用Hello的sayHello方法(实际上就是去调用HelloImpl的sayHello,因为我们将Hello的实现指定是HelloImpl)
  9. public void sayHello(){
  10. hello.sayHello() ;
  11. }
  12. }

通过@Inject注解将Hello属性的实例注入进来

(3)创建一个测试类Client

  1. package guice.di;
  2. import com.google.inject.Binder;
  3. import com.google.inject.Guice;
  4. import com.google.inject.Injector;
  5. import com.google.inject.Module;
  6. public class Client {
  7. //创建一个测试程序
  8. public static void main(String[] args) {
  9. Injector in = Guice.createInjector(new Module(){
  10. @Override
  11. public void configure(Binder arg0) {
  12. //什么也不写
  13. }
  14. }) ;
  15. //得到HelloCaller的实例
  16. HelloCaller helloCaller = in.getInstance(HelloCaller.class) ;
  17. //调用sayHello方法
  18. helloCaller.sayHello() ;
  19. }
  20. }

结果:

  1. HelloImpl Say Hello

二. 构造方法注入

(1)Hello和HelloImpl类还是上面那样不用变,唯一变化的是HelloCaller类

  1. package guice.di;
  2. import com.google.inject.Inject;
  3. public class HelloCaller1 {
  4. //包含一个Hello属性
  5. private Hello hello ;
  6. //@Inject注解写在构造方法上,通过构造方法的方式注入属性hello
  7. @Inject
  8. public HelloCaller1(Hello hello){
  9. this.hello = hello ;
  10. }
  11. public void sayHello(){
  12. hello.sayHello() ;
  13. }
  14. }

(2)创建测试程序

  1. package guice.di;
  2. import com.google.inject.Binder;
  3. import com.google.inject.Guice;
  4. import com.google.inject.Injector;
  5. import com.google.inject.Module;
  6. public class Client {
  7. //创建一个测试程序
  8. public static void main(String[] args) {
  9. Injector in = Guice.createInjector(new Module(){
  10. @Override
  11. public void configure(Binder arg0) {
  12. //什么也不写
  13. }
  14. }) ;
  15. //得到HelloCaller的实例
  16. HelloCaller1 helloCaller = in.getInstance(HelloCaller1.class) ;
  17. //调用sayHello方法
  18. helloCaller.sayHello() ;
  19. }
  20. }

结果:

HelloImpl Say Hello

三,setter方式注入

(1)Hello和HelloImpl类还是上面那样不用变,唯一变化的是HelloCaller类

  1. <span style="font-size:14px;">package guice.di;
  2. import com.google.inject.Inject;
  3. public class HelloCaller2 {
  4. <span style="white-space:pre">  </span>
  5. <span style="white-space:pre">  </span>private Hello hello ;
  6. <span style="white-space:pre">  </span>public Hello getHello() {
  7. <span style="white-space:pre">      </span>return hello;
  8. <span style="white-space:pre">  </span>}
  9. <span style="white-space:pre">  </span>//通过setter方法来注入hello属性
  10. <span style="white-space:pre">  </span>@Inject
  11. <span style="white-space:pre">  </span>public void setHello(Hello hello) {
  12. <span style="white-space:pre">      </span>this.hello = hello;
  13. <span style="white-space:pre">  </span>}
  14. <span style="white-space:pre">  </span>
  15. }</span>

(2)创建测试程序

  1. <span style="font-size:14px;">package guice.di;
  2. import com.google.inject.Binder;
  3. import com.google.inject.Guice;
  4. import com.google.inject.Injector;
  5. import com.google.inject.Module;
  6. public class Client {
  7. //创建一个测试程序
  8. public static void main(String[] args) {
  9. Injector in = Guice.createInjector(new Module(){
  10. @Override
  11. public void configure(Binder arg0) {
  12. //什么也不写
  13. }
  14. }) ;
  15. //得到HelloCaller的实例
  16. HelloCaller1 helloCaller = in.getInstance(HelloCaller1.class) ;
  17. //调用sayHello方法
  18. helloCaller.sayHello() ;
  19. }
  20. }</span>

结果:

HelloImpl Say Hello

上面介绍了Guice框架的三种注入方式:属性注入,构造方法注入,setter方法注入

Guice 注入(@Inject注解)的更多相关文章

  1. Spring中@Autowired、@Resource和@Inject注解的使用和区别

    在使用Spring进行项目开发的时候,会大量使用到自动装配,那自动装配是什么呢?简单来说:Spring 利用依赖注入(DI)功能,完成SpringIOC容器中各个组件之间的依赖关系赋值管理. 下面介绍 ...

  2. 【Spring注解驱动开发】你还不会使用@Resource和@Inject注解?那你就out了!!

    写在前面 我在 冰河技术 微信公众号中发表的<[Spring注解驱动开发]使用@Autowired@Qualifier@Primary三大注解自动装配组件,你会了吗?>一文中,介绍了如何使 ...

  3. Spring第四天,BeanPostProcessor源码分析,彻底搞懂IOC注入及注解优先级问题!

  4. Spring构造器注入、set注入和注解注入

    记得刚开始学spring的时候,老师就反复的提到依赖注入和切面,平常的java开发中,在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种方法耦合度太高并且不容易测试,sp ...

  5. Android so注入(inject)和Hook技术学习(三)——Got表hook之导出表hook

    前文介绍了导入表hook,现在来说下导出表的hook.导出表的hook的流程如下.1.获取动态库基值 void* get_module_base(pid_t pid, const char* modu ...

  6. Spring学习笔记1—依赖注入(构造器注入、set注入和注解注入)

    什么是依赖注入 在以前的java开发中,某个类中需要依赖其它类的方法时,通常是new一个依赖类再调用类实例的方法,这种方法耦合度太高并且不容易测试,spring提出了依赖注入的思想,即依赖类不由程序员 ...

  7. Android的so注入( inject)和函数Hook(基于got表) - 支持arm和x86

    本文博客地址:http://blog.csdn.net/qq1084283172/article/details/53942648 前面深入学习了古河的Libinject注入Android进程,下面来 ...

  8. spring下应用@Resource, @Autowired 和 @Inject注解进行依赖注入的差异

    为了探寻 '@Resource', '@Autowired', 和'@Inject'如何解决依赖注入中的问题,我创建了一个"Party"接口,和它的两个实现类"Perso ...

  9. Spring Bean 注入 2 注解篇

    1. 自动装配注解 配置applicationContext.xml开启注解 <?xml version="1.0" encoding="UTF-8"?& ...

随机推荐

  1. Z.XML第一次迭代分数分配

    紧张的第一次迭代落下帷幕,便到了分数分配这样令人揪心又无奈的日子.如何进行分数分配,以使大家都能满意,这一直是个难以非常好地处理的问题.幸运地是,我们团队的所有成员每个人都对本次迭代乃至整个项目过程付 ...

  2. 给Python初学者的一些编程建议

    Python是一种非常富有表现力的语言.它为我们提供了一个庞大的标准库和许多内置模块,帮助我们快速完成工作.然而,许多人可能会迷失在它提供的功能中,不能充分利用标准库,过度重视单行脚本,以及误解Pyt ...

  3. sql声明变量存储查询结果

    with t as 查到条件数据,然后在下面使用到t,用exists做判断会非常慢,改成left join会快很多. 我使用的数据库时2008Sql r2. 文章:SQL数据库中临时表.临时变量和WI ...

  4. lintcode-116-跳跃游戏

    116-跳跃游戏 给出一个非负整数数组,你最初定位在数组的第一个位置. 数组中的每个元素代表你在那个位置可以跳跃的最大长度. 判断你是否能到达数组的最后一个位置. 注意事项 这个问题有两个方法,一个是 ...

  5. 关于socket的疑问

    一直感觉一端发送数据,另一端接受数据很不可思议的事情,如果不能即时地读走会导致什么后果呢? 其实socket读出来的数据,你自己看着办,里面的数据是什么格式你自己去解析,用户可以基于TCP去实现你自己 ...

  6. ob_flush()和flush()的区别

    最近写定时任务,遇到ob_flush()和flush()混淆的问题... ob_flush/flush在手册中的描述, 都是刷新输出缓冲区, 并且还需要配套使用, 所以会导致很多人迷惑- 其实, 他们 ...

  7. [剑指Offer] 20.包含min函数的栈

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数. [思路1]两个栈Stack和Min,Stack为当前栈中元素,Min为与Stack中元素一一对应的当前栈最小值. cl ...

  8. 【AtCoder ARC076】F Exhausted? 霍尔定理+线段树

    题意 N个人抢M个椅子,M个椅子排成一排 ,第i个人只能坐[1,Li]∪[Ri,M],问最多能坐多少人 $i$人连边向可以坐的椅子构成二分图,题意即是求二分图最大完美匹配,由霍尔定理,答案为$max( ...

  9. 【bzoj1452】[JSOI2009]Count 二维树状数组

    题目描述 输入 输出 样例输入 样例输出 1 2 题解 二维树状数组 一开始没看到 1≤c≤100 ,想到了主X树和X块,结果发现c的范围那么小... 二维树状数组水题,和一维的一样,向上修改,向下查 ...

  10. hdu 3648 Median Filter (树状数组)

    Median Filter Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...