Class SyncOnSubscribe.SubscriptionProducer<S,T>
- Type Parameters:
T- the type of compatible Subscribers
- All Implemented Interfaces:
Serializable,Observer<T>,Producer,Subscription
- Enclosing class:
SyncOnSubscribe<S,T>
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final Subscriber<? super T> private booleanprivate booleanprivate final SyncOnSubscribe<S, T> private static final longprivate S -
Constructor Summary
ConstructorsConstructorDescriptionSubscriptionProducer(Subscriber<? super T> subscriber, SyncOnSubscribe<S, T> parent, S state) -
Method Summary
Modifier and TypeMethodDescriptionprivate voidprivate voidfastpath()private voidhandleThrownError(Subscriber<? super T> a, Throwable ex) booleanIndicates whether thisSubscriptionis currently unsubscribed.private voidnextIteration(SyncOnSubscribe<S, T> parent) voidNotifies the Observer that theObservablehas finished sending push-based notifications.voidNotifies the Observer that theObservablehas experienced an error condition.voidProvides the Observer with a new item to observe.voidrequest(long n) Request a certain maximum number of items from this Producer.private voidslowPath(long n) private booleanvoidStops 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:
-
actualSubscriber
-
parent
-
onNextCalled
private boolean onNextCalled -
hasTerminated
private boolean hasTerminated -
state
-
-
Constructor Details
-
SubscriptionProducer
SubscriptionProducer(Subscriber<? super T> subscriber, SyncOnSubscribe<S, T> parent, S state)
-
-
Method Details
-
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
-
tryUnsubscribe
private boolean tryUnsubscribe() -
doUnsubscribe
private void doUnsubscribe() -
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);
-
fastpath
private void fastpath() -
handleThrownError
-
slowPath
private void slowPath(long n) -
nextIteration
-
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<S>
-
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(). -
onNext
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).
-