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 boolean
private boolean
private final SyncOnSubscribe
<S, T> private static final long
private S
-
Constructor Summary
ConstructorsConstructorDescriptionSubscriptionProducer
(Subscriber<? super T> subscriber, SyncOnSubscribe<S, T> parent, S state) -
Method Summary
Modifier and TypeMethodDescriptionprivate void
private void
fastpath()
private void
handleThrownError
(Subscriber<? super T> a, Throwable ex) boolean
Indicates whether thisSubscription
is currently unsubscribed.private void
nextIteration
(SyncOnSubscribe<S, T> parent) void
Notifies the Observer that theObservable
has finished sending push-based notifications.void
Notifies the Observer that theObservable
has experienced an error condition.void
Provides the Observer with a new item to observe.void
request
(long n) Request a certain maximum number of items from this Producer.private void
slowPath
(long n) private boolean
void
Stops the receipt of notifications on theSubscriber
that 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
Methods 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:Subscription
Indicates whether thisSubscription
is currently unsubscribed.- Specified by:
isUnsubscribed
in interfaceSubscription
- Returns:
true
if thisSubscription
is currently unsubscribed,false
otherwise
-
unsubscribe
public void unsubscribe()Description copied from interface:Subscription
Stops the receipt of notifications on theSubscriber
that was registered when this Subscription was received.This allows unregistering an
Subscriber
before it has finished receiving all events (i.e. before onCompleted is called).- Specified by:
unsubscribe
in interfaceSubscription
-
tryUnsubscribe
private boolean tryUnsubscribe() -
doUnsubscribe
private void doUnsubscribe() -
request
public void request(long n) Description copied from interface:Producer
Request a certain maximum number of items from this Producer. This is a way of requesting backpressure. To disable backpressure, passLong.MAX_VALUE
to this method.Requests are additive but if a sequence of requests totals more than
Long.MAX_VALUE
thenLong.MAX_VALUE
requests will be actioned and the extras may be ignored. Arriving atLong.MAX_VALUE
by addition of requests cannot be assumed to disable backpressure. For example, the code below may result inLong.MAX_VALUE
requests 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:Observer
Notifies the Observer that theObservable
has finished sending push-based notifications.The
Observable
will not call this method if it callsObserver.onError(java.lang.Throwable)
.- Specified by:
onCompleted
in interfaceObserver<S>
-
onError
Description copied from interface:Observer
Notifies the Observer that theObservable
has experienced an error condition.If the
Observable
calls this method, it will not thereafter callObserver.onNext(T)
orObserver.onCompleted()
. -
onNext
Description copied from interface:Observer
Provides the Observer with a new item to observe.The
Observable
may call this method 0 or more times.The
Observable
will not call this method again after it calls eitherObserver.onCompleted()
orObserver.onError(java.lang.Throwable)
.
-