Package rx.internal.operators
Class OperatorReplay.InnerProducer<T>
- java.lang.Object
-
- java.lang.Number
-
- java.util.concurrent.atomic.AtomicLong
-
- rx.internal.operators.OperatorReplay.InnerProducer<T>
-
- Type Parameters:
T- the value type
- All Implemented Interfaces:
java.io.Serializable,Producer,Subscription
- Enclosing class:
- OperatorReplay<T>
static final class OperatorReplay.InnerProducer<T> extends java.util.concurrent.atomic.AtomicLong implements Producer, Subscription
A Producer and Subscription that manages the request and unsubscription state of a child subscriber in thread-safe manner. We use AtomicLong as a base class to save on extra allocation of an AtomicLong and also save the overhead of the AtomicIntegerFieldUpdater.
-
-
Field Summary
Fields Modifier and Type Field Description (package private) Subscriber<? super T>childThe actual child subscriber.(package private) booleanemittingIndicates an emission state.(package private) java.lang.ObjectindexHolds an object that represents the current location in the buffer.(package private) booleanmissedIndicates a missed update.(package private) OperatorReplay.ReplaySubscriber<T>parentThe parent subscriber-to-source used to allow removing the child in case of child unsubscription.private static longserialVersionUID(package private) java.util.concurrent.atomic.AtomicLongtotalRequestedKeeps the sum of all requested amounts.(package private) static longUNSUBSCRIBEDIndicates this child has been unsubscribed: the state is swapped in atomically and will prevent the dispatch() to emit (too many) values to a terminated child subscriber.
-
Constructor Summary
Constructors Constructor Description InnerProducer(OperatorReplay.ReplaySubscriber<T> parent, Subscriber<? super T> child)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description (package private) voidaddTotalRequested(long n)Increments the total requested amount.(package private) <U> Uindex()Convenience method to auto-cast the index object.booleanisUnsubscribed()Indicates whether thisSubscriptionis currently unsubscribed.longproduced(long n)Indicate that values have been emitted to this child subscriber by the dispatch() method.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
-
parent
final OperatorReplay.ReplaySubscriber<T> parent
The parent subscriber-to-source used to allow removing the child in case of child unsubscription.
-
child
Subscriber<? super T> child
The actual child subscriber.
-
index
java.lang.Object index
Holds an object that represents the current location in the buffer. Guarded by the emitter loop.
-
totalRequested
final java.util.concurrent.atomic.AtomicLong totalRequested
Keeps the sum of all requested amounts.
-
emitting
boolean emitting
Indicates an emission state. Guarded by this.
-
missed
boolean missed
Indicates a missed update. Guarded by this.
-
UNSUBSCRIBED
static final long UNSUBSCRIBED
Indicates this child has been unsubscribed: the state is swapped in atomically and will prevent the dispatch() to emit (too many) values to a terminated child subscriber.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
InnerProducer
public InnerProducer(OperatorReplay.ReplaySubscriber<T> parent, Subscriber<? super T> child)
-
-
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);
-
addTotalRequested
void addTotalRequested(long n)
Increments the total requested amount.- Parameters:
n- the additional request amount
-
produced
public long produced(long n)
Indicate that values have been emitted to this child subscriber by the dispatch() method.- Parameters:
n- the number of items emitted- Returns:
- the updated request value (may indicate how much can be produced or a terminal state)
-
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
-
index
<U> U index()
Convenience method to auto-cast the index object.- Returns:
-
-