Class QueuedProducer<T>
- java.lang.Object
-
- java.lang.Number
-
- java.util.concurrent.atomic.AtomicLong
-
- rx.internal.producers.QueuedProducer<T>
-
- Type Parameters:
T- the value type
public final class QueuedProducer<T> extends java.util.concurrent.atomic.AtomicLong implements Producer, Observer<T>
Producer that holds an unbounded (or custom) queue, handles terminal events, enqueues values and relays them to a child subscriber on request.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description (package private) Subscriber<? super T>child(package private) booleandone(package private) java.lang.Throwableerror(package private) static java.lang.ObjectNULL_SENTINEL(package private) java.util.Queue<java.lang.Object>queueprivate static longserialVersionUID(package private) java.util.concurrent.atomic.AtomicIntegerwip
-
Constructor Summary
Constructors Constructor Description QueuedProducer(Subscriber<? super T> child)Constructs an instance with the target child subscriber and an Spsc Linked (Atomic) Queue as the queue implementation.QueuedProducer(Subscriber<? super T> child, java.util.Queue<java.lang.Object> queue)Constructs an instance with the target child subscriber and a custom queue implementation
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description private booleancheckTerminated(boolean isDone, boolean isEmpty)private voiddrain()booleanoffer(T value)Offers a value to this producer and tries to emit any queued values if the child requests allow it.voidonCompleted()Notifies the Observer that theObservablehas finished sending push-based notifications.voidonError(java.lang.Throwable e)Notifies the Observer that theObservablehas experienced an error condition.voidonNext(T value)Provides the Observer with a new item to observe.voidrequest(long n)Request a certain maximum number of items from this Producer.-
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
-
queue
final java.util.Queue<java.lang.Object> queue
-
wip
final java.util.concurrent.atomic.AtomicInteger wip
-
error
java.lang.Throwable error
-
done
volatile boolean done
-
NULL_SENTINEL
static final java.lang.Object NULL_SENTINEL
-
-
Constructor Detail
-
QueuedProducer
public QueuedProducer(Subscriber<? super T> child)
Constructs an instance with the target child subscriber and an Spsc Linked (Atomic) Queue as the queue implementation.- Parameters:
child- the target child subscriber
-
QueuedProducer
public QueuedProducer(Subscriber<? super T> child, java.util.Queue<java.lang.Object> queue)
Constructs an instance with the target child subscriber and a custom queue implementation- Parameters:
child- the target child subscriberqueue- the queue to use
-
-
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);
-
offer
public boolean offer(T value)
Offers a value to this producer and tries to emit any queued values if the child requests allow it.- Parameters:
value- the value to enqueue and attempt to drain- Returns:
- true if the queue accepted the offer, false otherwise
-
onNext
public void onNext(T value)
Description copied from interface:ObserverProvides the Observer with a new item to observe.The
Observablemay call this method 0 or more times.The
Observablewill not call this method again after it calls eitherObserver.onCompleted()orObserver.onError(java.lang.Throwable).
-
onError
public void onError(java.lang.Throwable e)
Description copied from interface:ObserverNotifies the Observer that theObservablehas experienced an error condition.If the
Observablecalls this method, it will not thereafter callObserver.onNext(T)orObserver.onCompleted().
-
onCompleted
public void onCompleted()
Description copied from interface:ObserverNotifies the Observer that theObservablehas finished sending push-based notifications.The
Observablewill not call this method if it callsObserver.onError(java.lang.Throwable).- Specified by:
onCompletedin interfaceObserver<T>
-
checkTerminated
private boolean checkTerminated(boolean isDone, boolean isEmpty)
-
drain
private void drain()
-
-