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>,java.io.Serializable,org.reactivestreams.Subscriber<T>
- Enclosing class:
- ParallelFromPublisher<T>
static final class ParallelFromPublisher.ParallelDispatcher<T> extends java.util.concurrent.atomic.AtomicInteger implements FlowableSubscriber<T>
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description (package private) classParallelFromPublisher.ParallelDispatcher.RailSubscription
-
Field Summary
Fields Modifier and Type Field Description (package private) booleancancelled(package private) booleandone(package private) long[]emissions(package private) java.lang.Throwableerror(package private) intindex(package private) intlimit(package private) intprefetch(package private) intproduced(package private) SimpleQueue<T>queue(package private) java.util.concurrent.atomic.AtomicLongArrayrequestsprivate static longserialVersionUID(package private) intsourceMode(package private) java.util.concurrent.atomic.AtomicIntegersubscriberCountCounts how many subscribers were setup to delay triggering the drain of upstream until all of them have been setup.(package private) org.reactivestreams.Subscriber<? super T>[]subscribers(package private) org.reactivestreams.Subscriptionupstream
-
Constructor Summary
Constructors Constructor Description ParallelDispatcher(org.reactivestreams.Subscriber<? super T>[] subscribers, int prefetch)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description (package private) voidcancel(int m)(package private) voiddrain()(package private) voiddrainAsync()(package private) voiddrainSync()voidonComplete()voidonError(java.lang.Throwable t)voidonNext(T t)voidonSubscribe(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) voidsetupSubscribers()-
Methods 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, weakCompareAndSetVolatile
-
-
-
-
Field Detail
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
subscribers
final org.reactivestreams.Subscriber<? super T>[] subscribers
-
requests
final java.util.concurrent.atomic.AtomicLongArray requests
-
emissions
final long[] emissions
-
prefetch
final int prefetch
-
limit
final int limit
-
upstream
org.reactivestreams.Subscription upstream
-
queue
SimpleQueue<T> queue
-
error
java.lang.Throwable error
-
done
volatile boolean done
-
index
int index
-
cancelled
volatile boolean cancelled
-
subscriberCount
final java.util.concurrent.atomic.AtomicInteger 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 Detail
-
ParallelDispatcher
ParallelDispatcher(org.reactivestreams.Subscriber<? super T>[] subscribers, int prefetch)
-
-
Method Detail
-
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()
-
onError
public void onError(java.lang.Throwable t)
- 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()
-
-