Package rx.internal.operators
Class CachedObservable.ReplayProducer<T>
- java.lang.Object
-
- java.lang.Number
-
- java.util.concurrent.atomic.AtomicLong
-
- rx.internal.operators.CachedObservable.ReplayProducer<T>
-
- Type Parameters:
T-
- All Implemented Interfaces:
java.io.Serializable,Producer,Subscription
- Enclosing class:
- CachedObservable<T>
static final class CachedObservable.ReplayProducer<T> extends java.util.concurrent.atomic.AtomicLong implements Producer, Subscription
Keeps track of the current request amount and the replay position for a child Subscriber.
-
-
Field Summary
Fields Modifier and Type Field Description (package private) Subscriber<? super T>childThe actual child subscriber.(package private) java.lang.Object[]currentBufferContains the reference to the buffer segment in replay.(package private) intcurrentIndexInBufferContains the index into the currentBuffer where the next value is expected.(package private) booleanemittingIndicates there is a replay going on; guarded by this.(package private) intindexContains the absolute index up until the values have been replayed so far.(package private) booleanmissedIndicates there were some state changes/replay attempts; guarded by this.private static longserialVersionUID(package private) CachedObservable.CacheState<T>stateThe cache state object.
-
Constructor Summary
Constructors Constructor Description ReplayProducer(Subscriber<? super T> child, CachedObservable.CacheState<T> state)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanisUnsubscribed()Indicates whether thisSubscriptionis currently unsubscribed.longproduced(long n)Updates the request count to reflect values have been produced.voidreplay()Continue replaying available values if there are requests for them.voidrequest(long n)Request a certain maximum number of items from this Producer.voidunsubscribe()Stops the receipt of notifications on theSubscriberthat was registered when this Subscription was received.-
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
-
child
final Subscriber<? super T> child
The actual child subscriber.
-
state
final CachedObservable.CacheState<T> state
The cache state object.
-
currentBuffer
java.lang.Object[] currentBuffer
Contains the reference to the buffer segment in replay. Accessed after reading state.size() and when emitting == true.
-
currentIndexInBuffer
int currentIndexInBuffer
Contains the index into the currentBuffer where the next value is expected. Accessed after reading state.size() and when emitting == true.
-
index
int index
Contains the absolute index up until the values have been replayed so far.
-
emitting
boolean emitting
Indicates there is a replay going on; guarded by this.
-
missed
boolean missed
Indicates there were some state changes/replay attempts; guarded by this.
-
-
Constructor Detail
-
ReplayProducer
public ReplayProducer(Subscriber<? super T> child, CachedObservable.CacheState<T> state)
-
-
Method Detail
-
request
public void request(long n)
Description copied from interface:ProducerRequest a certain maximum number of items from this Producer. This is a way of requesting backpressure. To disable backpressure, passLong.MAX_VALUEto this method.Requests are additive but if a sequence of requests totals more than
Long.MAX_VALUEthenLong.MAX_VALUErequests will be actioned and the extras may be ignored. Arriving atLong.MAX_VALUEby addition of requests cannot be assumed to disable backpressure. For example, the code below may result inLong.MAX_VALUErequests being actioned only.request(100); request(Long.MAX_VALUE-1);
-
produced
public long produced(long n)
Updates the request count to reflect values have been produced.- Parameters:
n- the produced item count, positive, not validated- Returns:
- the latest request amount after subtracting n
-
isUnsubscribed
public boolean isUnsubscribed()
Description copied from interface:SubscriptionIndicates whether thisSubscriptionis currently unsubscribed.- Specified by:
isUnsubscribedin interfaceSubscription- Returns:
trueif thisSubscriptionis currently unsubscribed,falseotherwise
-
unsubscribe
public void unsubscribe()
Description copied from interface:SubscriptionStops the receipt of notifications on theSubscriberthat was registered when this Subscription was received.This allows unregistering an
Subscriberbefore it has finished receiving all events (i.e. before onCompleted is called).- Specified by:
unsubscribein interfaceSubscription
-
replay
public void replay()
Continue replaying available values if there are requests for them.
-
-