目录引入api使用依赖注入(Dependency Injection)和服务定位器(Service Locator)是实现控制反转(Inversion of Control)的两种主
依赖注入(Dependency Injection)和服务定位器(Service Locator)是实现控制反转(Inversion of Control)的两种主要手段。
Android的主流依赖注入框架有:Dagger 和 Kion
这些依赖注入框架都感觉比较重。
服务定位器比如少见,这里提供一个一个简单的服务定位器模式实现。
repositories {
Maven { url "https://gitee.com/ezy/repo/raw/android_public/"}
}
dependencies {
implementation "me.reezy.jetpack:servicelocator:0.4.0"
}
// 获取实例
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获得的都是同一实例
class SomeService {
fun doSomething() {
}
}
// 注册
singleton {
SomeService()
}
// 获取
val service = resolve<SomeService>()
具名单例
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都会产生新实例
class SomeService {
fun doSomething() {
}
}
// 注册
factory {
SomeService()
}
// 获取,每次resolve都会产生新实例
val service1 = resolve<SomeService>()
val service2 = resolve<SomeService>()
具名工厂
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 简单服务定位器模式实现的详细内容,更多关于Android 简单服务定位器模式的资料请关注编程网其它相关文章!
--结束END--
本文标题: Android 简单服务定位器模式实现
本文链接: https://lsjlt.com/news/122453.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-21
2023-10-28
2023-10-28
2023-10-27
2023-10-27
2023-10-27
2023-10-27
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0