当前位置: 首页 > 知识库问答 >
问题:

类型推断失败:信息不足,无法推断参数T Kotlin

闻人越
2023-03-14

我使用一个密封类从网络返回数据。但是当我在构建这个项目时,我得到了以下错误

类型推断失败:没有足够的信息来推断参数T in fun error(错误消息:String,错误:Throwable):状态请明确指定它。

我错过了什么?

这是代码

suspend fun getdataFromApi(context: Context?, token: String?): State<ScheduleReminderListResponse> =
    withContext(schedulerProvider.io)
    {

            try {
                val list = network.getScheduleReminderList(token).await()
                schedeleReminderListLocalDao.insertAll(list)
                return@withContext State.success(list)
            } catch (e: Exception) {
                return@withContext State.error( e.message ?: "Unknown Error",  e  )
            }


        }






sealed class State<T> {

class Loading<T>: State<T>()
data class Error<T>(val errorMessage: String?, val error: Throwable): State<T>()
data class Success<T>(var data: T) : State<T>()

companion object {
    fun <T> loading(): State<T> =
        Loading()

    fun <T> error(errorMessage: String, error: Throwable): State<T> =
        Error(errorMessage, error)

    fun <T> success(data: T): State<T> =
        Success(data)

   }
 }

共有3个答案

从阎宝
2023-03-14

与@s1m0nw1答案相反,如果您想将类型参数保留在State模型中(以便返回值美观且类型安全),您可以考虑将T标记为out并在不使用它的子类中使用

sealed class State<out T> {

    object Loading: State<Nothing>()
    data class Error(val errorMessage: String?, val error: Throwable): State<Nothing>()
    data class Success<T>(var data: T): State<T>()

    companion object {
        fun <T> loading(): State<T> = Loading

        fun <T> error(errorMessage: String, error: Throwable): State<T> = Error(errorMessage, error)

        fun <T> success(data: T): State<T> = Success(data)
    }
}

这样,示例方法将保持不变,并且不需要执行不安全的强制转换

秦光启
2023-03-14

Errordata类定义了T类型参数,但不以任何方式使用它。因此,当您创建Error实例时,编译器无法推断T应该使用什么类型。

要解决此问题,请更改状态错误的定义,使它们没有类型参数。

白飞飙
2023-03-14

在这行状态中。错误(e.message?:“未知错误”,e)编译器不知道T应该是什么。如果将其与success进行比较,就会发现显式提供了T的参数,编译器使用该参数推断类型。调用错误时,可以这样指定:

State.error<TYPE_OF_SCHEDULE_REMINDER_LIST>( e.message ?: "Unknown Error",  e  )

由于您没有在Error中使用T,因此您可能需要考虑将其完全从密封类中删除,并且仅在有意义的地方使用它。

sealed class State {

    object Loading : State()
    data class Error(val errorMessage: String?, val error: Throwable) : State()
    data class Success<T>(var data: T) : State()

    companion object {
        fun loading(): State = Loading

        fun error(errorMessage: String, error: Throwable): Error =
            Error(errorMessage, error)

        fun <T> success(data: T): Success<T> = Success(data)
    }
}
 类似资料:
  • 我有一个比较来自两个不同endpoint的响应的函数。它看起来像这样: 如您所见,调用方可以传入有关如何从两个终结点的响应生成响应字符串的函数。我还有一个响应生成器的默认函数。它们看起来像这样: 这在IntelliJ中编译得很好。然而,当我运行gradle构建时,它失败了,并显示错误 我做错了什么?我在毕业设计中使用了Kotlin 1.6.10。

  • 在一个纯Kotlin项目中,我使用JUnit Jupiter 5.5.2和AssertJ3.10.0。以下测试成功执行: 一旦我更新到AssertJ3.11.1,测试构建就会失败,出现以下消息: 我试图弄清楚发生了什么--但没有成功。 JUnit5问题#1209:在没有显式指定泛型类型的情况下,无法在Kotlin中调用“fail”

  • 我正在尝试用科特林编写一个Vaadin应用程序。对于数据绑定,Vaadin 8 现在提供了类型安全数据绑定的可能性。在科特林,我本来以为会有这样的工作: 我在这里收到以下错误消息: 我尝试通过显式指定类型参数: 但是这导致了错误消息(和其他sytax错误,所以我没有遵循这种方法) 我的第二种方法是尝试直接传递Kotlin属性访问器,但错误消息与第一种方法相同: 最后一个方法是尝试使用扩展方法并使一

  • 当用户确认付款时,我尝试在Paypal Sdk上获取交易详细信息。但是,下面的代码遇到了问题 遇到的问题: 类型推断失败:信息不足,无法推断中的参数T 享乐 对于此行:val confirm=data。getParcelableExtra(PaymentActivity.EXTRA_结果_确认) 不确定这对字符串(4)意味着什么: val paymentDetails=confirm。toJSON

  • 我的分类测试应用程序有一个问题,我使用了一个比较器。我收到一条信息: 线程“主”java.lang 中的异常:未解决的编译问题:无法推断排序器的类型参数 对于该代码: 分拣机类: 可比接口: id比较器类: 比较器接口: 这样用有什么错?我怎样才能做得更好?

  • 我正试图为我的android应用程序编写一些测试,这对我来说是一个挑战。这个错误是许多障碍之一 哪一个发生在这条线上 完整的测试代码如下所示 基本上,shadowOf函数是重载的,可以返回很多thinks,我需要指定类型。 我相信它应该是类似< code>shadowOf的东西 任何帮助都将不胜感激。 EDIT我遵循机器人技术指南,但尝试用androidX的方式编写