1

我正在将一些 Java 代码转换为 Kotlin,但遇到了一些问题flattenAsObservable()

Java 中的代码如下所示:

discogsInteractor.search(query)
    .map(RootSearchResponse::getSearchResults)
    .flattenAsObservable(searchResults -> searchResults)
    .take(12)

这是我目前在 Kotlin 中所拥有的:

discogsInteractor.search(query)
    .map { RootSearchResponse::searchResults }
    .flattenAsObservable<SearchResult> { searchResults -> searchResults }
    .take(12)

它强调了第二个searchResults并给了我以下错误:

Required: (Mutable)Iterable<SearchResult!>!
Found: KProperty1<RootSearchResponse, List<SearchResult>>!

我可以换

.map { RootSearchResponse::searchResults }

.map { searchResponse -> searchResponse.searchResults }

它会起作用。如何正确参考方法?或者在这种情况下我不能的原因是什么?

根搜索响应:

data class RootSearchResponse(val pagination: Pagination,
                              @SerializedName("results") val searchResults: List<SearchResult>)
4

1 回答 1

2

RootSearchResponse::searchResults是方法参考。map通过使用{},您不是将 this 传递给函数,而是传递一个始终返回此方法引用的 lambda。

基本上,您通过map操作将每个传入元素映射到该方法引用,而不是像您想要的那样将该方法应用于每个元素。因此,您方法的传入参数flattenAsObservable始终是对该searchResults方法的相同引用,即KProperty1.

要将您引用的方法应用于每个元素,您可以在常规括号中传递方法引用,如下所示:

.map(RootSearchResponse::searchResults)

有关 lambda 发生的事情的另一个简单示例:

listOf(1, 2, 3, 4, 5).map { 2 }

此操作会将每个元素映射到2,您最终会得到一个仅包含2五次的列表。它基本上只是以下内容的简写,只是没有明确的参数名称:

listOf(1, 2, 3, 4, 5).map { x -> 2 }
于 2017-05-29T15:31:18.650 回答