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>,java.io.Serializable,org.reactivestreams.Subscriber<T>,org.reactivestreams.Subscription
- Enclosing class:
- FlowableGroupBy<T,K,V>
public static final class FlowableGroupBy.GroupBySubscriber<T,K,V> extends java.util.concurrent.atomic.AtomicLong implements FlowableSubscriber<T>, org.reactivestreams.Subscription
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description (package private) intbufferSize(package private) java.util.concurrent.atomic.AtomicBooleancancelled(package private) booleandelayError(package private) booleandone(package private) org.reactivestreams.Subscriber<? super GroupedFlowable<K,V>>downstream(package private) longemittedGroups(package private) java.util.Queue<FlowableGroupBy.GroupedUnicast<K,V>>evictedGroups(package private) java.util.concurrent.atomic.AtomicLonggroupConsumed(package private) java.util.concurrent.atomic.AtomicIntegergroupCount(package private) java.util.Map<java.lang.Object,FlowableGroupBy.GroupedUnicast<K,V>>groups(package private) Function<? super T,? extends K>keySelector(package private) intlimit(package private) static java.lang.ObjectNULL_KEYprivate static longserialVersionUID(package private) org.reactivestreams.Subscriptionupstream(package private) Function<? super T,? extends V>valueSelector
-
Constructor Summary
Constructors Constructor Description 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, java.util.Map<java.lang.Object,FlowableGroupBy.GroupedUnicast<K,V>> groups, java.util.Queue<FlowableGroupBy.GroupedUnicast<K,V>> evictedGroups)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidcancel()voidcancel(K key)private voidcompleteEvictions()(package private) static MissingBackpressureExceptiongroupHangWarning(long n)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).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, weakCompareAndSetVolatile
-
-
-
-
Field Detail
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
downstream
final org.reactivestreams.Subscriber<? super GroupedFlowable<K,V>> downstream
-
bufferSize
final int bufferSize
-
limit
final int limit
-
delayError
final boolean delayError
-
groups
final java.util.Map<java.lang.Object,FlowableGroupBy.GroupedUnicast<K,V>> groups
-
evictedGroups
final java.util.Queue<FlowableGroupBy.GroupedUnicast<K,V>> evictedGroups
-
NULL_KEY
static final java.lang.Object NULL_KEY
-
upstream
org.reactivestreams.Subscription upstream
-
cancelled
final java.util.concurrent.atomic.AtomicBoolean cancelled
-
emittedGroups
long emittedGroups
-
groupCount
final java.util.concurrent.atomic.AtomicInteger groupCount
-
groupConsumed
final java.util.concurrent.atomic.AtomicLong groupConsumed
-
done
boolean done
-
-
Constructor Detail
-
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, java.util.Map<java.lang.Object,FlowableGroupBy.GroupedUnicast<K,V>> groups, java.util.Queue<FlowableGroupBy.GroupedUnicast<K,V>> evictedGroups)
-
-
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>
-
groupHangWarning
static MissingBackpressureException groupHangWarning(long n)
-
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>
-
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
public void cancel(K key)
-
requestGroup
void requestGroup(long n)
-
-