我实现了一个名为“FilterByLatestFrom”的伪运算符,作为kotlin的扩展功能。
我使用此运算符编写了下一个代码:
fun testFilterByLatestFromOperator(){
val observableA : Observable<Int> = Observable.fromArray(1,2,3,4,5,6,7,8,9,10)
val observableC : PublishSubject<Int> = PublishSubject.create()
val observableB : Observable<Int> = Observable.just(2).mergeWith(observableC)
observableB.subscribe { println("observableB onNext: $it") }
observableA
.subscribe({ println("Original : $it")})
observableA.filterByLatestFrom(observableB, BiFunction { aVal, bVal -> aVal%bVal==0 })
.subscribe({ println("Result A : $it") })
observableC.onNext(3)
observableA.filterByLatestFrom(observableB, BiFunction { aVal, bVal -> aVal%bVal==0 })
.subscribe({ println("Result AC : $it") })
}
输出为:
observableB onNext: 2
Original : 1
Original : 2
Original : 3
Original : 4
Original : 5
Original : 6
Original : 7
Original : 8
Original : 9
Original : 10
Result A : 2
Result A : 4
Result A : 6
Result A : 8
Result A : 10
observableB onNext: 3
Result AC : 2
Result AC : 4
Result AC : 6
Result AC : 8
Result AC : 10
我希望过滤器运算符将根据可观测B的最后一个值过滤obsA。
它适用于第一个块,但是当我用新值添加On-next时,它不会改变结果(使用与原始可观察值相同的最后一个值)。
这是FilterByLatestFrom impl(它也被设计用于Java(带有compose):
class FilterByLatestFrom<T,U>(private val observable: Observable<T>, private val biFunction: BiFunction<U, T, Boolean>){
fun filter() : ObservableTransformer<U,U> = ObservableTransformer {
it
.withLatestFrom(
observable,
BiFunction<U,T,Pair<U,Boolean>> {
u, t -> Pair(u,biFunction.apply(u,t))
})
.filter { it.second }
.map { it.first }
}
}
fun <T,U> Observable<U>.filterByLatestFrom(observable: Observable<T>, biFunction: BiFunction<U, T, Boolean>) : Observable<U> =
this.compose(FilterByLatestFrom(observable,biFunction).filter())
我想念什么?
编辑:我认为我发现了问题:PublishSubject应该改为BehaviorSubject。并且合并功能应为conacat,以保证obsC将在obsB之后发出。
最佳答案
您的伪运算符filterByLatestFrom
很好,问题出在测试之内,PublishSubject
将仅发出后续项,因此,在您的最后一次订阅(“结果AC”)中,observableB
仅发出2,因为observableC
已经发出3,并且将不要将其重播为observableB
(使用merge
)。
只需将observableC.onNext(3)
移到最后一个订阅(最后一行)之后,即可看到预期的行为。
编辑:
就像您确实解决了相同的问题一样,也更改为PublishSubject
(主题将重播新订阅的最后一个值)