當前位置: 首頁>>代碼示例>>Java>>正文


Java UnicastProcessor類代碼示例

本文整理匯總了Java中io.reactivex.processors.UnicastProcessor的典型用法代碼示例。如果您正苦於以下問題:Java UnicastProcessor類的具體用法?Java UnicastProcessor怎麽用?Java UnicastProcessor使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


UnicastProcessor類屬於io.reactivex.processors包,在下文中一共展示了UnicastProcessor類的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: toStreamCancel

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Test
public void toStreamCancel() {
    UnicastProcessor<Integer> up = UnicastProcessor.create();

    up.onNext(1);
    up.onNext(2);
    up.onNext(3);
    up.onNext(4);
    up.onNext(5);

    try (Stream<Integer> s = up
            .to(FlowableInterop.toStream()).limit(3)) {
        Assert.assertTrue(up.hasSubscribers());

        List<Integer> list = s.collect(Collectors.toList());
        Assert.assertEquals(Arrays.asList(1, 2, 3), list);
    }

    Assert.assertFalse(up.hasSubscribers());
}
 
開發者ID:akarnokd,項目名稱:RxJava2Jdk8Interop,代碼行數:21,代碼來源:FlowableInteropTest.java

示例2: mapOptionalAsyncFused

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Test
public void mapOptionalAsyncFused() {
    TestSubscriber<Integer> ts = TestHelper.fusedSubscriber(QueueSubscription.ANY);

    UnicastProcessor<Integer> up = UnicastProcessor.create();
    TestHelper.emit(up, 1, 2, 3, 4, 5);

    up
    .compose(FlowableInterop.mapOptional(v -> {
        if (v % 2 == 0) {
            return Optional.of(-v);
        }
        return Optional.empty();
    }))
    .subscribeWith(ts)
    .assertOf(TestHelper.assertFusedSubscriber(QueueSubscription.ASYNC))
    .assertResult(-2, -4);
}
 
開發者ID:akarnokd,項目名稱:RxJava2Jdk8Interop,代碼行數:19,代碼來源:FlowableInteropTest.java

示例3: mapOptionalAsyncFusedConditional

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Test
public void mapOptionalAsyncFusedConditional() {
    TestSubscriber<Integer> ts = TestHelper.fusedSubscriber(QueueSubscription.ANY);

    UnicastProcessor<Integer> up = UnicastProcessor.create();
    TestHelper.emit(up, 1, 2, 3, 4, 5);

    up
    .compose(FlowableInterop.mapOptional(v -> {
        if (v % 2 == 0) {
            return Optional.of(-v);
        }
        return Optional.empty();
    }))
    .filter(Functions.alwaysTrue())
    .subscribeWith(ts)
    .assertOf(TestHelper.assertFusedSubscriber(QueueSubscription.ASYNC))
    .assertResult(-2, -4);
}
 
開發者ID:akarnokd,項目名稱:RxJava2Jdk8Interop,代碼行數:20,代碼來源:FlowableInteropTest.java

示例4: WindowPredicateSubscriber

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
WindowPredicateSubscriber(Subscriber<? super Flowable<T>> actual,
        Predicate<? super T> predicate, Mode mode,
        int bufferSize) {
    super(1);
    this.actual = actual;
    this.predicate = predicate;
    this.mode = mode;
    this.bufferSize = bufferSize;
    // In Mode.BEFORE windows are opened earlier and added to the 1-element drain "queue"
    if (mode == Mode.BEFORE) {
        requestedWindows = new AtomicLong();
        pending = new AtomicReference<UnicastProcessor<T>>();
    } else {
        requestedWindows = null;
        pending = null;
    }
}
 
開發者ID:akarnokd,項目名稱:RxJava2Extensions,代碼行數:18,代碼來源:FlowableWindowPredicate.java

示例5: runAsyncProcessor

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Test
public void runAsyncProcessor() {
    AsyncFlowable.runAsync(Schedulers.single(),
        UnicastProcessor.<Object>create(),
    new BiConsumer<Subscriber<Object>, Disposable>() {
        @Override
        public void accept(Subscriber<? super Object> s, Disposable d) throws Exception {
            s.onNext(1);
            s.onNext(2);
            s.onNext(3);
            Thread.sleep(200);
            s.onNext(4);
            s.onNext(5);
            s.onComplete();
        }
    })
    .test()
    .awaitDone(5, TimeUnit.SECONDS)
    .assertResult(1, 2, 3, 4, 5);
}
 
開發者ID:akarnokd,項目名稱:RxJava2Extensions,代碼行數:21,代碼來源:AsyncFlowableTest.java

示例6: drain

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
private void drain() {
    if (requestedWindows.get() <= 0) {
        return;
    }
    UnicastProcessor<T> w = pending.getAndSet(null);
    if (w == null) {
        return;
    }
    getAndIncrement();
    requestedWindows.getAndDecrement();
    actual.onNext(w);
}
 
開發者ID:akarnokd,項目名稱:RxJava2Extensions,代碼行數:13,代碼來源:FlowableWindowPredicate.java

示例7: tryOnNext

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Override
public boolean tryOnNext(T t) {
    UnicastProcessor<T> w = window;
    if (w == null) {
        // ignore additional items after last window is completed
        if (cancelled.get()) {
            return true;
        }
        // emit next window
        w = UnicastProcessor.<T>create(bufferSize, this);
        window = w;
        getAndIncrement();
        if (mode == Mode.BEFORE) {
            requestedWindows.getAndDecrement();
        }
        actual.onNext(w);
    }

    boolean b;

    try {
        // negate predicate for windowWhile
        b = predicate.test(t) ^ mode == Mode.BEFORE;
    } catch (Throwable ex) {
        Exceptions.throwIfFatal(ex);
        s.cancel();
        actual.onError(ex);
        w.onError(ex);
        window = null;
        return true;
    }

    if (b) {
        // element goes into current window
        if (mode == Mode.AFTER) {
            w.onNext(t);
        }
        // finish current window
        w.onComplete();
        // element goes into the next requested window
        if (mode == Mode.BEFORE) {
            w = UnicastProcessor.<T>create(bufferSize, this);
            window = w;
            w.onNext(t);
            // add window to drain queue
            pending.set(w);
            // try emitting right away
            drain();
        } else {
            // new window emitted on next upstream item
            window = null;
        }
    } else {
        w.onNext(t);
    }
    return b;
}
 
開發者ID:akarnokd,項目名稱:RxJava2Extensions,代碼行數:58,代碼來源:FlowableWindowPredicate.java

示例8: asyncFused

import io.reactivex.processors.UnicastProcessor; //導入依賴的package包/類
@Test
public void asyncFused() {
    UnicastProcessor<Integer> up = UnicastProcessor.create();
    MulticastProcessor<Integer> mp = MulticastProcessor.create(4);

    up.subscribe(mp);

    TestSubscriber<Integer> ts = mp.test();

    for (int i = 0; i < 10; i++) {
        up.onNext(i);
    }

    assertFalse(mp.offer(10));

    up.onComplete();

    ts.assertResult(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
}
 
開發者ID:akarnokd,項目名稱:RxJava2Extensions,代碼行數:20,代碼來源:MulticastProcessorTest.java


注:本文中的io.reactivex.processors.UnicastProcessor類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。