依赖注入(Dependency Injection)和服务定位器(Service Locator)是实现控制反转(Inversion of Control)的两种主要手段。
Android的主流依赖注入框架有:Dagger 和 Kion
这些依赖注入框架都感觉比较重。
服务定位器比如少见,这里提供一个一个简单的服务定位器模式实现。
引入
项目地址:github.com/czy1121/ser…
| 1 2 3 4 5 6 | repositories { maven { url "https://gitee.com/ezy/repo/raw/android_public/"}} dependencies { implementation "me.reezy.jetpack:servicelocator:0.4.0"} |
API
| 1 2 3 4 5 6 | // 获取实例inline fun <reified T> resolve(name: String = T::class.java.name): T?// 注册为单例inline fun <reified T> singleton(name: String = T::class.java.name, crossinline block: () -> T)// 注册为工厂inline fun <reified T> factory(name: String = T::class.java.name, crossinline block: () -> T) |
使用
单例,每次resolve获得的都是同一实例
| 1 2 3 4 5 6 7 8 9 10 11 12 | class SomeService { fun doSomething() { }}// 注册 singleton { SomeService()}// 获取val service = resolve<SomeService>() |
具名单例
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | class NamedService(val name: String) { fun doSomething() { }}// 注册 singleton("a") { NamedService("aaa")}singleton("b") { NamedService("bbb")}// 获取 val serviceA = resolve<NamedService>("a")val serviceB = resolve<NamedService>("b") |
工厂,每次resolve都会产生新实例
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | class SomeService { fun doSomething() { }}// 注册 factory { SomeService()}// 获取,每次resolve都会产生新实例val service1 = resolve<SomeService>() val service2 = resolve<SomeService>() |
具名工厂
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | class NamedService(val name: String) { fun doSomething() { }}// 注册 factory("a") { NamedService("aaa")}factory("b") { NamedService("bbb")}// 获取// A1 与 A2 是使用同一工厂产生的不同实例// A1 与 B1 是使用不同工厂产生的不同实例val serviceA1 = resolve<NamedService>("a")val serviceA2 = resolve<NamedService>("a")val serviceB1 = resolve<NamedService>("b")val serviceB2 = resolve<NamedService>("b") |
以上就是Android 简单服务定位器模式实现的详细内容

