lan*_*nyf 4 class kotlin retrofit2
具有基类A,并且类B和C都从A延伸
在A它有创建改装服务的功能,它将类类型作为pram:
protected fun <T> createRemoteService(clazz: Class<T>, baseUrl: String): T {
return Retrofit.Builder()
.baseUrl(baseUrl)
.client(okHttpClient)
.addConverterFactory(GsonConverterFactory.create(createGson()))
.build()
.create(clazz)
}
Run Code Online (Sandbox Code Playgroud)
在B和C类中,服务可以创建为(分别传入IBService :: class.java或ICService :: class.java):
在B:
var remoteServ: IBService
init {
remoteApi = createRemoteService(IBService::class.java, getBaseUrl())
}
Run Code Online (Sandbox Code Playgroud)
在C:
var remoteServ: ICService
init {
remoteApi = createRemoteService(ICService::class.java, getBaseUrl())
}
Run Code Online (Sandbox Code Playgroud)
可以通过IBService::class.java作为Class<T>
想在基类A中有一个抽象函数来返回类类型
abstract fun<T> getRemoteServiceClassType() : Class<T>
Run Code Online (Sandbox Code Playgroud)
所以它可以在基类A中完成,通过获取类类型来创建服务
remoteServ: Any = createRemoteApi(getRemoteServiceClassType(), getBaseUrl())
Run Code Online (Sandbox Code Playgroud)
并在B类中实现(得到错误):
override fun<T> getRemoteServiceClassType() : Class<T> {
return IBService::class.java //<=== got compiler error “Type inference
// failed. Expected type mismatch: required Class<T>
// found Class<IBService>
}
interface IBService {
@GET
fun getRemoteData(@Url url: String,
@HeaderMap headers: Map<String, String>,
@QueryMap params: Map<String, String>?):
Call<BResponseData>
}
Run Code Online (Sandbox Code Playgroud)
为什么不能返回IBService::java.class的Class<T>,但路过IBService::class.java的地方,需要一个功能Class<T>是确定的?
"正确"的签名getRemoteServiceClassType是
abstract fun getRemoteServiceClassType() : Class<*>
Run Code Online (Sandbox Code Playgroud)
如果任何课程都可以退还,或者
abstract fun getRemoteServiceClassType() : Class<out SuperType>
Run Code Online (Sandbox Code Playgroud)
如果所有服务都应该有一个共同的超类型.有关说明,请参阅https://kotlinlang.org/docs/reference/generics.html.
| 归档时间: |
|
| 查看次数: |
2841 次 |
| 最近记录: |