Obligatorio <Objeto> y encontrado <Objeto>?

class TaskRepo(taskData: TaskData) { companion object { private val repoByTask: LRUMap<String, OrderFormRepo> = LRUMap(2, 10); fun getInstance(taskData: TaskData): OrderFormRepo { if (notFoundObject(taskData.taskId)) { repoByTask[taskData.taskId] = OrderFormRepo(taskData); } return repoByTask[taskData.taskId];//PROBLEM HERE } private fun notFoundObject(taskId: String): Boolean { if (repoByTask.containsKey(taskId) && repoByTask[taskId] != null) { return false } return true } } 

}

en el método getInstance del object complementario, estoy obteniendo un error de time de compilation : ¿Se requiere TaskRepo y encontré TaskRepo?

LRUMap implementa la interfaz Map , cuyo método get en Kotlin devuelve una V? , ya que devuelve null cuando no hay ningún elemento presente para la key dada.

Como ya ha hecho la verificación de antemano en este caso, puede estar razonablemente seguro (suponiendo que no haya otros subprocesss modificando el map al mismo time) de que este valor no será nulo y forzará una conversión a la que no admite nulos. escribe con el !! operador :

 return repoByTask[taskData.taskId]!! 

Para otras forms de manejar una key faltante al leer desde un Map , vea los methods getOrDefault y getOrElse .

  • cómo implementar Switch usando Data binding en android
  • ¿Cómo escalar dinámicamente el rebote de la stream de emisión de ráfagas?
  • RxJava2 Tal vez devuelva Observable vacío si no hay elemento
  • RxKotlin collectInto () MutableList usando references de método
  • Cómo pasar nulo a un Observable con tipo anulable en RxJava 2 y Kotlin
  • Agregar subscribeOn () está cambiando el tipo de retorno de observable
  • Llamada asincrónica para cada elemento dentro de una colección
  • Confusión de la syntax de Kotlin lambda
  • Comportamiento con Kotlin Higher-Order Functions e interfaces de método único?
  • No se puede cambiar el text de ActionMenuItemView con RxKotlin
  • Inyectar constructor y object complementario