Class FlowableGroupBy.GroupBySubscriber<T,K,V>
java.lang.Object
java.lang.Number
java.util.concurrent.atomic.AtomicLong
io.reactivex.rxjava3.internal.operators.flowable.FlowableGroupBy.GroupBySubscriber<T,K,V>
- All Implemented Interfaces:
FlowableSubscriber<T>,Serializable,org.reactivestreams.Subscriber<T>,org.reactivestreams.Subscription
- Enclosing class:
FlowableGroupBy<T,K, V>
public static final class FlowableGroupBy.GroupBySubscriber<T,K,V>
extends AtomicLong
implements FlowableSubscriber<T>, org.reactivestreams.Subscription
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) final int(package private) final AtomicBoolean(package private) final boolean(package private) boolean(package private) final org.reactivestreams.Subscriber<? super GroupedFlowable<K, V>> (package private) long(package private) final Queue<FlowableGroupBy.GroupedUnicast<K, V>> (package private) final AtomicLong(package private) final AtomicInteger(package private) final Map<Object, FlowableGroupBy.GroupedUnicast<K, V>> (package private) final int(package private) static final Objectprivate static final long(package private) org.reactivestreams.Subscription -
Constructor Summary
ConstructorsConstructorDescriptionGroupBySubscriber(org.reactivestreams.Subscriber<? super GroupedFlowable<K, V>> actual, Function<? super T, ? extends K> keySelector, Function<? super T, ? extends V> valueSelector, int bufferSize, boolean delayError, Map<Object, FlowableGroupBy.GroupedUnicast<K, V>> groups, Queue<FlowableGroupBy.GroupedUnicast<K, V>> evictedGroups) -
Method Summary
Modifier and TypeMethodDescriptionvoidcancel()voidprivate void(package private) static MissingBackpressureExceptiongroupHangWarning(long n) voidvoidvoidvoidonSubscribe(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).voidrequest(long n) (package private) voidrequestGroup(long n) Methods inherited from class java.util.concurrent.atomic.AtomicLong
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:
-
downstream
-
keySelector
-
valueSelector
-
bufferSize
final int bufferSize -
limit
final int limit -
delayError
final boolean delayError -
groups
-
evictedGroups
-
NULL_KEY
-
upstream
org.reactivestreams.Subscription upstream -
cancelled
-
emittedGroups
long emittedGroups -
groupCount
-
groupConsumed
-
done
boolean done
-
-
Constructor Details
-
GroupBySubscriber
public GroupBySubscriber(org.reactivestreams.Subscriber<? super GroupedFlowable<K, V>> actual, Function<? super T, ? extends K> keySelector, Function<? super T, ? extends V> valueSelector, int bufferSize, boolean delayError, Map<Object, FlowableGroupBy.GroupedUnicast<K, V>> groups, Queue<FlowableGroupBy.GroupedUnicast<K, V>> evictedGroups)
-
-
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>
-
onNext
- Specified by:
onNextin interfaceorg.reactivestreams.Subscriber<T>
-
groupHangWarning
-
onError
- Specified by:
onErrorin interfaceorg.reactivestreams.Subscriber<T>
-
onComplete
public void onComplete()- Specified by:
onCompletein interfaceorg.reactivestreams.Subscriber<T>
-
request
public void request(long n) - Specified by:
requestin interfaceorg.reactivestreams.Subscription
-
cancel
public void cancel()- Specified by:
cancelin interfaceorg.reactivestreams.Subscription
-
completeEvictions
private void completeEvictions() -
cancel
-
requestGroup
void requestGroup(long n)
-