Class ParallelFromPublisher.ParallelDispatcher<T>
java.lang.Object
java.lang.Number
java.util.concurrent.atomic.AtomicInteger
io.reactivex.rxjava3.internal.operators.parallel.ParallelFromPublisher.ParallelDispatcher<T>
- All Implemented Interfaces:
FlowableSubscriber<T>,Serializable,org.reactivestreams.Subscriber<T>
- Enclosing class:
ParallelFromPublisher<T>
static final class ParallelFromPublisher.ParallelDispatcher<T>
extends AtomicInteger
implements FlowableSubscriber<T>
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescription(package private) final class -
Field Summary
FieldsModifier and TypeFieldDescription(package private) boolean(package private) boolean(package private) final long[](package private) Throwable(package private) int(package private) final int(package private) final int(package private) int(package private) SimpleQueue<T> (package private) final AtomicLongArrayprivate static final long(package private) int(package private) final AtomicIntegerCounts how many subscribers were setup to delay triggering the drain of upstream until all of them have been setup.(package private) final org.reactivestreams.Subscriber<? super T>[](package private) org.reactivestreams.Subscription -
Constructor Summary
ConstructorsConstructorDescriptionParallelDispatcher(org.reactivestreams.Subscriber<? super T>[] subscribers, int prefetch) -
Method Summary
Modifier and TypeMethodDescription(package private) voidcancel(int m) (package private) voiddrain()(package private) void(package private) voidvoidvoidvoidvoidonSubscribe(org.reactivestreams.Subscription s) Implementors of this method should make sure everything that needs to be visible inSubscriber.onNext(Object)is established before callingSubscription.request(long).(package private) voidMethods inherited from class java.util.concurrent.atomic.AtomicInteger
accumulateAndGet, addAndGet, compareAndExchange, compareAndExchangeAcquire, compareAndExchangeRelease, compareAndSet, decrementAndGet, doubleValue, floatValue, get, getAcquire, getAndAccumulate, getAndAdd, getAndDecrement, getAndIncrement, getAndSet, getAndUpdate, getOpaque, getPlain, incrementAndGet, intValue, lazySet, longValue, set, setOpaque, setPlain, setRelease, toString, updateAndGet, weakCompareAndSet, weakCompareAndSetAcquire, weakCompareAndSetPlain, weakCompareAndSetRelease, weakCompareAndSetVolatileMethods inherited from class java.lang.Number
byteValue, shortValue
-
Field Details
-
serialVersionUID
private static final long serialVersionUID- See Also:
-
subscribers
-
requests
-
emissions
final long[] emissions -
prefetch
final int prefetch -
limit
final int limit -
upstream
org.reactivestreams.Subscription upstream -
queue
SimpleQueue<T> queue -
error
Throwable error -
done
volatile boolean done -
index
int index -
cancelled
volatile boolean cancelled -
subscriberCount
Counts how many subscribers were setup to delay triggering the drain of upstream until all of them have been setup. -
produced
int produced -
sourceMode
int sourceMode
-
-
Constructor Details
-
ParallelDispatcher
ParallelDispatcher(org.reactivestreams.Subscriber<? super T>[] subscribers, int prefetch)
-
-
Method Details
-
onSubscribe
public void onSubscribe(org.reactivestreams.Subscription s) Description copied from interface:FlowableSubscriberImplementors of this method should make sure everything that needs to be visible inSubscriber.onNext(Object)is established before callingSubscription.request(long). In practice this means no initialization should happen after therequest()call and additional behavior is thread safe in respect toonNext.- Specified by:
onSubscribein interfaceFlowableSubscriber<T>- Specified by:
onSubscribein interfaceorg.reactivestreams.Subscriber<T>
-
setupSubscribers
void setupSubscribers() -
onNext
- Specified by:
onNextin interfaceorg.reactivestreams.Subscriber<T>
-
onError
- Specified by:
onErrorin interfaceorg.reactivestreams.Subscriber<T>
-
onComplete
public void onComplete()- Specified by:
onCompletein interfaceorg.reactivestreams.Subscriber<T>
-
cancel
void cancel(int m) -
drainAsync
void drainAsync() -
drainSync
void drainSync() -
drain
void drain()
-