我正在尝试使用子类中的方法getInstance
。
知道为什么提到的方法不可访问以及如何更改此代码以便我可以访问它吗?
出于好奇,这个示例结构来自尝试在Android上对Room数据库类进行子类化。
open class SingletonHolder<out T: Any, in A>(creator: (A) -> T) {
private var creator: ((A) -> T)? = creator
@Volatile private var instance: T? = null
fun getInstance(arg: A): T {
val i = instance
if (i != null) {
return i
}
return synchronized(this) {
val i2 = instance
if (i2 != null) {
i2
} else {
val created = creator!!(arg)
instance = created
creator = null
created
}
}
}
}
abstract class subclass(val par: Int): superclass(par) {
abstract fun function1()
}
class subclass_Impl(val par1: Int): subclass(par1) {
override fun function1() {
Log.d("unused", "unused")
}
override fun f2() {
Log.d("this is", "subclass Impl")
}
}
abstract class superclass(val dummy: Int) {
abstract fun f2()
companion object : SingletonHolder<superclass, Int>( { Builder.build(it) } )
}
class superclass_Impl(val par: Int): superclass(par) {
override fun f2() {
Log.d("this is", "superclass_Impl")
}
}
class Builder {
companion object {
fun build(par: Int): superclass_Impl {
return superclass_Impl(par)
}
}
}
class test {
fun test1() {
superclass.getInstance(1).f2()
subclass.getInstance(1).f2() // getInstance is not visible ??
}
}
SingletonHolder
类是从kotlin中的惰性实现派生的,并允许将参数传递给creator函数。 https://medium.com/@BladeCoder/kotlin-singletons-with-argument-194ef06edd9e
superclass
在Android上模仿abstract class MyRoomDatabase : RoomDatabase()
,这将在运行时创建sqlite db的实例,建议将其实现为单例。就我而言,这是在服务内部。 superclass_Impl
将由会议室库创建。
subclass
是MyRoomDatabase
的子类,它位于将连接到该服务的客户端上。我试图扩展它以添加仅由客户端使用的查询方法。 subclass_Impl
将由会议室库创建。
答案 0 :(得分:2)
很明显,您认为静态成员是在Java中继承的,并且由于伴随对象是同一件事,所以我应该能够做到以下几点。
subclass.getInstance() // as in question, subclass is name of the class not its instance
对不起,这是不允许的。随播对象不是Java的静态成员。 Kotlin被设计为不需要这种构造的语言。因此,请勿尝试使用Kotlin功能编写Java代码。
如果要像引用Java的静态成员一样引用comapnion对象成员,则必须指定伴随对象的包含类的名称。就您而言
superclass.getInstance(1).f2()