Class FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber<T,B,V>
- java.lang.Object
-
- java.lang.Number
-
- java.util.concurrent.atomic.AtomicInteger
-
- io.reactivex.rxjava3.internal.operators.flowable.FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber<T,B,V>
-
- All Implemented Interfaces:
FlowableSubscriber<T>,java.io.Serializable,java.lang.Runnable,org.reactivestreams.Subscriber<T>,org.reactivestreams.Subscription
- Enclosing class:
- FlowableWindowBoundarySelector<T,B,V>
static final class FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber<T,B,V> extends java.util.concurrent.atomic.AtomicInteger implements FlowableSubscriber<T>, org.reactivestreams.Subscription, java.lang.Runnable
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description (package private) static classFlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowEndSubscriberIntercept<T,V>(package private) static classFlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowStartItem<B>(package private) static classFlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowStartSubscriber<B>
-
Field Summary
Fields Modifier and Type Field Description (package private) intbufferSize(package private) Function<? super B,? extends org.reactivestreams.Publisher<V>>closingIndicator(package private) org.reactivestreams.Subscriber<? super Flowable<T>>downstream(package private) java.util.concurrent.atomic.AtomicBooleandownstreamCancelled(package private) longemitted(package private) AtomicThrowableerror(package private) org.reactivestreams.Publisher<B>open(package private) booleanopenDone(package private) SimplePlainQueue<java.lang.Object>queue(package private) java.util.concurrent.atomic.AtomicLongrequested(package private) CompositeDisposableresourcesprivate static longserialVersionUID(package private) FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowStartSubscriber<B>startSubscriber(package private) org.reactivestreams.Subscriptionupstream(package private) booleanupstreamCanceled(package private) booleanupstreamDone(package private) java.util.concurrent.atomic.AtomicLongwindowCount(package private) java.util.List<UnicastProcessor<T>>windows
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidcancel()(package private) voidclose(FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowEndSubscriberIntercept<T,V> what)(package private) voidcloseError(java.lang.Throwable t)(package private) voiddrain()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) voidopen(B startValue)(package private) voidopenComplete()(package private) voidopenError(java.lang.Throwable t)voidrequest(long n)voidrun()(package private) voidterminateDownstream(org.reactivestreams.Subscriber<?> downstream)-
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
-
open
final org.reactivestreams.Publisher<B> open
-
closingIndicator
final Function<? super B,? extends org.reactivestreams.Publisher<V>> closingIndicator
-
bufferSize
final int bufferSize
-
resources
final CompositeDisposable resources
-
startSubscriber
final FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowStartSubscriber<B> startSubscriber
-
windows
final java.util.List<UnicastProcessor<T>> windows
-
queue
final SimplePlainQueue<java.lang.Object> queue
-
windowCount
final java.util.concurrent.atomic.AtomicLong windowCount
-
downstreamCancelled
final java.util.concurrent.atomic.AtomicBoolean downstreamCancelled
-
requested
final java.util.concurrent.atomic.AtomicLong requested
-
emitted
long emitted
-
upstreamCanceled
volatile boolean upstreamCanceled
-
upstreamDone
volatile boolean upstreamDone
-
openDone
volatile boolean openDone
-
error
final AtomicThrowable error
-
upstream
org.reactivestreams.Subscription upstream
-
-
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>
-
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
-
run
public void run()
- Specified by:
runin interfacejava.lang.Runnable
-
open
void open(B startValue)
-
openError
void openError(java.lang.Throwable t)
-
openComplete
void openComplete()
-
close
void close(FlowableWindowBoundarySelector.WindowBoundaryMainSubscriber.WindowEndSubscriberIntercept<T,V> what)
-
closeError
void closeError(java.lang.Throwable t)
-
drain
void drain()
-
terminateDownstream
void terminateDownstream(org.reactivestreams.Subscriber<?> downstream)
-
-