Guice是Google开发的一个轻量级,基于Java5(主要运用
泛型与注释特性)的依赖注入框架(IOC)。Guice非常小而且快。Guice是
类型安全的,它能够对
构造函数,属性,方法(包含任意个参数的任意方法,而不仅仅是setter方法)进行注入。Guice采用Java加注解的方式进行托管对象的配置,充分利用IDE编译器的类型安全检查功能和自动重构功能,使得配置的更改也是类型安全的。Guice提供模块对应的抽象module,使得架构和设计的模块概念产物与代码中的module类一一对应,更加便利的组织和梳理模块依赖关系,利于整体应用内部的依赖关系维护,而其他IOC框架是没有对应物的。此外,借助privateModule的功能,可以实现模块接口的明确导出和实现封装,使得支持多数据源这类需求实现起来异常简单。
Guice还具有一些可选的特性比如:自定义scopes,传递依赖,
静态属性注入,与
Spring集成和
AOP联盟方法注入等。
一部分人认为,Guice可以完全替代
spring, 因为对于DI组件框架来说, 性能是很重要的, guice比spring快十倍左右, 另外, 也是最
重要的一点, 使用spring很容易写成service locator的风格, 而用guice, 你会很自然的形成DI风格.
甚至说,guice简单超轻量级的DI框架效率是spring的1.6倍,Spring使用
XML使用将类与类之间的关系隔离到xml中,由容器负责注入被调用的对象,而guice将类与类之间的关系隔离到
Module中,声明何处需要注入,由容器根据Module里的描述,注入被调用的对象,使用
Annotation使用支持自定义Annotation标注,对于相同的接口定义的
对象引用,为它们标注上不同的自定义Annotation注释,就可以达到同一个类里边的同一个接口的引用,注射给不同的实现,在Module里用标注做区分,灵活性大大增加。
看下边的例子:对于不同社会形态下一个人(
java对象,调用者)需要一把斧子(java对象,被调用者)。
劳动社会基本没有分工,需要斧子的人(调用者)只好自己去磨一把斧子,每个人拥有自己的斧子,如果把大家的石斧改为铁斧,需要每个人都要学会磨铁斧的本领,工作效率极低。对应Java里的情形是:java程序里的调用者new一个被调用者的实例。类
耦合度极高,修改维护烦琐,效率极低。
工厂出现,斧子不再由普通人完成,而由工厂生产,当人们需要斧子的时候,可以到工厂购买斧子,无需关心斧子是怎么制造出来的,如果废弃铁斧为钢斧,只需改变工厂的制造工艺即可,制作工艺是工厂决定的,工厂生产什么斧子,工人们就得用什么斧子。对应的java里的情形是:
Java程序的调用者可以以来
简单工厂创建被调用者,变化点被隔离到了简单工厂里,虽然
耦合度降低,但是调用者会和工厂
耦合,而且需要定位自己的工厂
工厂蓬勃发展,人们需要什么斧子,只需要提供一个斧子图形,商家会按照你提供的图形将你的斧子订做好,送上门。对应
Java里的情形:
spring的依赖注入
信息进入现代化,人们不再去工厂购买斧子,不再拘泥于需要什么斧子事先画好什么样的图形,只需要打个电话,描述一下需要什么类型的斧子,或许想打造一个物美价廉的斧子,商家会根据市场零件的价格,计算出最优制作工艺,打造最适合的斧子送过来,更加信息化,更加人性化。对应
Java里的情形:基于描述的注入,动态的,灵活简单的注入,如:Guice。对于该不该使用Guice,我想也是仁者见仁,智者见智,就像好多论坛里动不动有人会在那里讨论到底学Java还是学
.net或者是使用
eclipse还是
Jbuilder的这类无聊话题,适合和满足
项目需求的,又能省工省力简单的完成工作的,就是最好的。