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 AtomicLongArray
private static final long
(package private) int
(package private) final AtomicInteger
Counts 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) void
cancel
(int m) (package private) void
drain()
(package private) void
(package private) void
void
void
void
void
onSubscribe
(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) void
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
Methods 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:FlowableSubscriber
Implementors 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:
onSubscribe
in interfaceFlowableSubscriber<T>
- Specified by:
onSubscribe
in interfaceorg.reactivestreams.Subscriber<T>
-
setupSubscribers
void setupSubscribers() -
onNext
- Specified by:
onNext
in interfaceorg.reactivestreams.Subscriber<T>
-
onError
- Specified by:
onError
in interfaceorg.reactivestreams.Subscriber<T>
-
onComplete
public void onComplete()- Specified by:
onComplete
in interfaceorg.reactivestreams.Subscriber<T>
-
cancel
void cancel(int m) -
drainAsync
void drainAsync() -
drainSync
void drainSync() -
drain
void drain()
-