Kodein-DI 7.0.0(一):初识Kodein_DI
2020-08-06 本文已影响0人
何意悲欢0_o
-
简述
Kodein-DI是一个非常实用的依赖注入框架,实际上,Kodein并不是一个依赖注入库,官方称之为依赖注入容器,它非常易于使用和配置。
为什么要使用Kodein-DI:
-
懒加载实例,只有在需要使用的时候,才会初始化对象。
-
不必关心依赖初始化顺序,kodein会自动查找需要使用的对象。
-
通过
provider
或factory
,可以很容易将类或接口绑定到它们的实例。 -
易于调试。
Kodein-DI的优点:
- 体积小,速度快,经过优化(广泛使用内联)。
- 使用DSL语法,简单易读。
- 不受泛型擦除的影响(比如Java)。
- 100%兼容Java、Android。
- 使用kolin风格编码
-
-
简单示例
kotlin的绑定很简单:
val di = DI { bind<Dice>() with provider { RandomDice() } }
声明绑定后,Kodein-DI允许注入或检索类之间的依赖关系。如果不想让类了解依赖关系,则可以在类构造时注入依赖关系:
class Controller(private val dice: Dice) { /*...*/ } //初始化Controller val controller: Controller by di.newInstance { Controller(instance()) } /*...*/
如果希望类自行处理依赖关系,可以使用这种方式初始化
class Controller(override val di: DI) : DIAware { private val dice by instance<Dice>() /*...*/ } //初始化Controller val controller: Controller = Controller(di) /*...*/
-
平台兼容性
从6.3.0开始,Kodein-DI在JVM上最低支持版本为JDK1.8
从7.0.0开始,开发人员不再需要在
erased
与generic
之间进行选择,Kodein-DI使用generic
进行泛型绑定。因此,无论是什么平台,bind<List<String>>
与bind<List<Int>>
都代表两种不同的绑定。从7.0开始,Kodein-DI可以将泛型用于非JVM平台,这是默认实现。但是,仍然可以通过
erased
方式强制擦除泛型。但是对于所有平台来说,类型支持都是基于kotlin的
typeOf()
函数,JVM类型使用了大量反射,因此其优化程度较低。