Kotlin:如何使用嵌套列表映射列表

Yas*_*Ali 3 performance android datamapper kotlin

我想将网络 DTO(其余 api 响应)转换为 Kotlin 中的数据库 DTO。网络 DTO 包含一个列表作为字段,该列表中的项目还包含其他数据的列表。下面是网络响应或网络DTO的表示

{
   categories: [
      {
         catId: 0,
         name: "Category A",
         products: [
             {
                 prodId: 900,
                 name: "Product 1"
                 ingredients: [
                     {
                         name: "Ingre 1"
                     }
                 ]
             }
         ]
      }
   ]
}
Run Code Online (Sandbox Code Playgroud)

我想提取并转换所有类别的列表,然后将所有产品的列表,然后将所有成分的列表转换为三个单独的列表,并且还想将这些数据转换为各自的数据库 DTO。

我已经创建了一段代码来执行所需的任务,但我确信存在性能问题,并且必须有一些更 kotlinish 的解决方案。

val dbCategories = networkCategories?.map {
                    DBCategory(
                            catId = it.catId,
                            name = it.name
                    )
                }

val dbProducts = networkCategories?.map { it.networkProducts }?.map {
                it.map { singleNetworkProduct ->
                    DBProduct(
                            prodId = singleNetworkProduct.prodId,
                            name = singleNetworkProduct.name,
                    )
                }
            }?.flatten() // flatten to remove the nested array lists created by repeated map functions
Run Code Online (Sandbox Code Playgroud)

在上面的代码中,为了简单起见,我跳过了成分数组的提取。

Bob*_*Bob 5

使用FlatMap

val dbProducts = networkCategories.flatMap { it. networkProducts }
    .map { DBProduct( ... ) }

val dbIngredients = networkCategories.flatMap { it. networkProducts }
    .flatMap { it.networkIngredients }.map { DBIngredient( ... ) }
Run Code Online (Sandbox Code Playgroud)

如果您因为网络列表迭代多次而担心性能问题,并且只想迭代原始网络列表一次,那么您可以使用普通for循环 或forEach,并自行将项目添加到三个可变列表中。

或者,您可以使用mapTo

val dbProducts = mutableListOf<DBProduct>()
val dbIngredients = mutableListOf<DBIngredient>()

val dbCategories = networkCategories.map {

    it.products.mapTo(dbProducts) {

        it.ingredients.mapTo(dbIngredients) {
            DBIngredient( ... )
        }

        DBProduct( ... )
    }

    DBCategory( ... )
}
Run Code Online (Sandbox Code Playgroud)