如何使用响应式扩展按空闲时段对事件进行分组

马特·帕塞尔(Matt Passell)

我有一个问题,即Reactive Extensions似乎特别适合。我有一个事件源,该事件源以较短的突发创建事件,并且之间有相对较长的空闲时间。我想将这些事件分组(理想情况下),其中每个突发事件都将在一批中结束。使用RxJava,有什么好方法吗?Observable.buffer(Observable)Observable.buffer(Func0)看起来很有希望,但是使用Observable.window()或Observable.groupByUntil()可能是可行的

本杰克里斯滕森

以下代码似乎适用于去抖动的缓冲区:

import java.util.List;
import java.util.concurrent.TimeUnit;

import rx.Observable;
import rx.Subscriber;
import rx.schedulers.Schedulers;

public class DebounceBuffer {

    public static void main(String args[]) {
        // see all bursts in a single sequence
        //        intermittentBursts().toBlocking().forEach(System.out::println);

        // debounce to the last value in each burst
        //        intermittentBursts().debounce(10, TimeUnit.MILLISECONDS).toBlocking().forEach(System.out::println);

        /* The following will emit a buffered list as it is debounced */
        // first we multicast the stream ... using refCount so it handles the subscribe/unsubscribe
        Observable<Integer> burstStream = intermittentBursts().publish().refCount();
        // then we get the debounced version
        Observable<Integer> debounced = burstStream.debounce(10, TimeUnit.MILLISECONDS);
        // then the buffered one that uses the debounced stream to demark window start/stop
        Observable<List<Integer>> buffered = burstStream.buffer(debounced);
        // then we subscribe to the buffered stream so it does what we want
        buffered.take(20).toBlocking().forEach(System.out::println);
    }

    public static Observable<Integer> intermittentBursts() {
        return Observable.create((Subscriber<? super Integer> s) -> {
            while (!s.isUnsubscribed()) {
                // burst some number of items
                for (int i = 0; i < Math.random() * 20; i++) {
                    s.onNext(i);
                }
                try {
                    // sleep for a random amount of time
                    Thread.sleep((long) (Math.random() * 1000));
                } catch (Exception e) {
                    // do nothing
                }
            }
        }).subscribeOn(Schedulers.newThread()); // use newThread since we are using sleep to block
    }

}

它发出以下信息:

[0, 1, 2, 3, 4, 5, 6, 7]
[0, 1, 2, 3, 4, 5]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1]
[0, 1, 2, 3, 4, 5]
[0, 1, 2]
[0, 1, 2, 3, 4, 5, 6, 7]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1, 2, 3, 4, 5, 6]
[0, 1, 2]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1, 2, 3, 4]
[0, 1, 2, 3]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1, 2, 3, 4, 5, 6, 7]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 1, 2, 3]
[0]
[0, 1, 2]
[0]

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何按周对事件进行分组和计数?

如何按年,月,日对事件列表进行分组

使用KnockoutJS按日期对事件进行分组

按Splunk中的多个字段对事件进行分组

按年份和月份对事件进行分组

Spring Integration中如何使用聚合器对事件进行分组/批处理

如果在nodejs中给出了繁忙时段,如何查找一天的空闲时段

如何找到与Outlook 2013约会的下一个空闲时段?

在 R 中,您可以按长度对事件之间的间隔进行分组吗?

按开始日期对事件进行排序

在空闲时使用 Pandas

进行查询以按IP对事物进行分组

如何使用本机JS代码以角度实现空闲时间?

如何对事件使用OpenAPI / Swagger规范?

如何在RXJS 5+中按时间有效地对事件进行分组

如何生成抛物面并使其对事件做出响应

如何使用SQL在给定的时间窗口内对事件时间进行排名?

对事件使用委托

如何对事件进行反跳?(语法错误?)

如何基于DataFrame中的多个条件对事件进行计数

让用户对事件进行RSVP?

使用RabbitMQ发布/订阅微服务事件总线时如何对事件进行重复数据删除

Google Calendar API:获取指定日期的空闲时段列表

如何(重新)设置空闲时间?

空闲时如何缩小HDInsight / Spark群集?

如何获取空闲时触发的任务列表?

脚本如何检测用户的空闲时间?

如何测量通道的空闲时间?

splunk 按日志事件中的大小列对事件进行排序