使用Kotlin函数功能如何使这段代码更好?

时间:2019-07-10 00:39:13

标签: android kotlin functional-programming kotlin-android-extensions

我有这些代码,我不喜欢我有mapNotNull,并且内部还有其他返回null的案例,我认为我的kotlin知识不足以使它变得更好,有什么想法吗?

    return config.mainMenus.mapNotNull { mainMenu ->
      val subPage = config.subPages.find {
        if (mainMenu.actions.isNotEmpty()) {
          it.id == mainMenu.actions.first().contentId
        } else {
          false
        }
      }
      if (subPage?.items?.isNotEmpty() != null) {
        MenuItem(mainMenu.type, mainMenu.titles, mainMenu.actions[0].type, subPage.items)
      } else {
        null
      }
    }
  }


  val programs = cards.mapNotNull { card ->
              if (card is Program) {
                epgRepository.getProgramProgress(currentTime = currentTime, program = card)
              } else {
                null
              }
            }

1 个答案:

答案 0 :(得分:1)

您可以将以前的代码替换为

            return config.mainMenus.mapNotNull { mainMenu ->
        config.subPages
                .find{mainMenu.actions.firstOrNull()?.contentId?.equals(it.id)?:false}
                ?.let{menu->
                    MenuItem(mainMenu.type, mainMenu.titles, mainMenu.actions[0].type, menu.items).takeIf{menu.items?.isNotEmpty()==true}
                }?:null
    }
}

第二个可能是

  val programs = cards.
      filterIsInstance<Program>().
      map { epgRepository.getProgramProgress(currentTime = currentTime, program = card)}

在这种情况下,您首先要过滤集合,使其仅获取程序中的元素,并且仅将这些元素转换为函数getProgramProcess返回的类型