Package rx.internal.operators
Class OnSubscribeFromAsync.BaseAsyncEmitter<T>
java.lang.Object
java.lang.Number
java.util.concurrent.atomic.AtomicLong
rx.internal.operators.OnSubscribeFromAsync.BaseAsyncEmitter<T>
- All Implemented Interfaces:
Serializable,AsyncEmitter<T>,Observer<T>,Producer,Subscription
- Direct Known Subclasses:
OnSubscribeFromAsync.BufferAsyncEmitter,OnSubscribeFromAsync.LatestAsyncEmitter,OnSubscribeFromAsync.NoneAsyncEmitter,OnSubscribeFromAsync.NoOverflowBaseAsyncEmitter
- Enclosing class:
OnSubscribeFromAsync<T>
abstract static class OnSubscribeFromAsync.BaseAsyncEmitter<T>
extends AtomicLong
implements AsyncEmitter<T>, Producer, Subscription
-
Nested Class Summary
Nested classes/interfaces inherited from interface rx.AsyncEmitter
AsyncEmitter.BackpressureMode, AsyncEmitter.Cancellable -
Field Summary
FieldsModifier and TypeFieldDescription(package private) final Subscriber<? super T> (package private) final SerialSubscriptionprivate static final long -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal booleanIndicates whether thisSubscriptionis currently unsubscribed.voidNotifies the Observer that theObservablehas finished sending push-based notifications.voidNotifies the Observer that theObservablehas experienced an error condition.(package private) void(package private) voidfinal voidrequest(long n) Request a certain maximum number of items from this Producer.final longThe current outstanding request amount.final voidSets a Cancellable on this emitter; any previous Subscription or Cancellation will be unsubscribed/cancelled.final voidSets a Subscription on this emitter; any previous Subscription or Cancellation will be unsubscribed/cancelled.final voidStops 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, weakCompareAndSetVolatileMethods inherited from class java.lang.Number
byteValue, shortValue
-
Field Details
-
serialVersionUID
private static final long serialVersionUID- See Also:
-
actual
-
serial
-
-
Constructor Details
-
BaseAsyncEmitter
-
-
Method Details
-
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>
-
onError
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(). -
unsubscribe
public final 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
-
onUnsubscribed
void onUnsubscribed() -
isUnsubscribed
public final boolean isUnsubscribed()Description copied from interface:SubscriptionIndicates whether thisSubscriptionis currently unsubscribed.- Specified by:
isUnsubscribedin interfaceSubscription- Returns:
trueif thisSubscriptionis currently unsubscribed,falseotherwise
-
request
public final 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);
-
onRequested
void onRequested() -
setSubscription
Description copied from interface:AsyncEmitterSets a Subscription on this emitter; any previous Subscription or Cancellation will be unsubscribed/cancelled.- Specified by:
setSubscriptionin interfaceAsyncEmitter<T>- Parameters:
s- the subscription, null is allowed
-
setCancellation
Description copied from interface:AsyncEmitterSets a Cancellable on this emitter; any previous Subscription or Cancellation will be unsubscribed/cancelled.- Specified by:
setCancellationin interfaceAsyncEmitter<T>- Parameters:
c- the cancellable resource, null is allowed
-
requested
public final long requested()Description copied from interface:AsyncEmitterThe current outstanding request amount.This method it threadsafe.
- Specified by:
requestedin interfaceAsyncEmitter<T>- Returns:
- the current outstanding request amount
-