本文整理匯總了Java中io.reactivex.processors.UnicastProcessor.create方法的典型用法代碼示例。如果您正苦於以下問題:Java UnicastProcessor.create方法的具體用法?Java UnicastProcessor.create怎麽用?Java UnicastProcessor.create使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類io.reactivex.processors.UnicastProcessor
的用法示例。
在下文中一共展示了UnicastProcessor.create方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的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());
}
示例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);
}
示例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);
}
示例4: 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;
}
示例5: 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);
}