RxJava:如何在序列中找到较小的数字

Die*_*mar 4 android reactive-programming rx-java

我正在尝试使用RxJava在序列中找到较小的数字.这是我第一次尝试解决这个问题.它有效(我得到了1)因为我仍然是RxJava的新手我百分百肯定有一个更好的解决方案:

    Observable<List<Integer>> sequence = Observable.create(new Observable.OnSubscribe<List<Integer>>() {
        @Override
        public void call(Subscriber<? super List<Integer>> subscriber) {
            subscriber.onNext(Arrays.asList(new Integer[]{10, 9, 8, null, 1, 2, 3, 4}));
            subscriber.onCompleted();
        }
    });

    final int[] minValue = {Integer.MAX_VALUE};

    sequence.flatMap(numList -> Observable.from(numList))
            .filter(number -> number != null)
            .filter(number -> {
                if (number < minValue[0]) {
                    minValue[0] = number;
                    return true;
                } else {
                    return false;
                }
            })
            .last()
            .subscribe(number -> {
                Log.i("App", "The smaller value in the sequence is " + number);
            });
Run Code Online (Sandbox Code Playgroud)

关于如何正确地做到这一点的任何建议?:)

kjo*_*nes 11

使用rxjava-math模块,min()运算符将执行您想要的操作.

sequence
    .flatMap(numList -> Observable.from(numList)
    .filter(number -> number != null)
    .min()
    .subscribe(number -> {
        Log.i("App", "The smaller value in the sequence is " + number);
    });
Run Code Online (Sandbox Code Playgroud)

您还可以使用reduce()滚动自己的min()版本

sequence
    .flatMap(numList -> Observable.from(numList)
    .filter(number -> number != null)
    .reduce(Integer.MAX_VALUE, 
        (currentMin, number) -> number < currentMin ? number : currentMin)
    .filter(number -> number != Integer.MAX_VALUE)
    .subscribe(number -> {
        Log.i("App", "The smaller value in the sequence is " + number);
    });
Run Code Online (Sandbox Code Playgroud)