Class BlockingFlowableIterable.BlockingFlowableIterator<T>

java.lang.Object
java.util.concurrent.atomic.AtomicReference<org.reactivestreams.Subscription>
io.reactivex.rxjava3.internal.operators.flowable.BlockingFlowableIterable.BlockingFlowableIterator<T>
All Implemented Interfaces:
FlowableSubscriber<T>, Disposable, Serializable, Runnable, Iterator<T>, org.reactivestreams.Subscriber<T>
Enclosing class:
BlockingFlowableIterable<T>

static final class BlockingFlowableIterable.BlockingFlowableIterator<T> extends AtomicReference<org.reactivestreams.Subscription> implements FlowableSubscriber<T>, Iterator<T>, Runnable, Disposable
  • Field Details

    • serialVersionUID

      private static final long serialVersionUID
      See Also:
    • queue

      final SpscArrayQueue<T> queue
    • batchSize

      final long batchSize
    • limit

      final long limit
    • lock

      final Lock lock
    • condition

      final Condition condition
    • produced

      long produced
    • done

      volatile boolean done
    • error

      volatile Throwable error
  • Constructor Details

    • BlockingFlowableIterator

      BlockingFlowableIterator(int batchSize)
  • Method Details

    • hasNext

      public boolean hasNext()
      Specified by:
      hasNext in interface Iterator<T>
    • next

      public T next()
      Specified by:
      next in interface Iterator<T>
    • onSubscribe

      public void onSubscribe(org.reactivestreams.Subscription s)
      Description copied from interface: FlowableSubscriber
      Implementors of this method should make sure everything that needs to be visible in Subscriber.onNext(Object) is established before calling Subscription.request(long). In practice this means no initialization should happen after the request() call and additional behavior is thread safe in respect to onNext.
      Specified by:
      onSubscribe in interface FlowableSubscriber<T>
      Specified by:
      onSubscribe in interface org.reactivestreams.Subscriber<T>
    • onNext

      public void onNext(T t)
      Specified by:
      onNext in interface org.reactivestreams.Subscriber<T>
    • onError

      public void onError(Throwable t)
      Specified by:
      onError in interface org.reactivestreams.Subscriber<T>
    • onComplete

      public void onComplete()
      Specified by:
      onComplete in interface org.reactivestreams.Subscriber<T>
    • signalConsumer

      void signalConsumer()
    • run

      public void run()
      Specified by:
      run in interface Runnable
    • remove

      public void remove()
      Specified by:
      remove in interface Iterator<T>
    • dispose

      public void dispose()
      Description copied from interface: Disposable
      Dispose the resource, the operation should be idempotent.
      Specified by:
      dispose in interface Disposable
    • isDisposed

      public boolean isDisposed()
      Description copied from interface: Disposable
      Returns true if this resource has been disposed.
      Specified by:
      isDisposed in interface Disposable
      Returns:
      true if this resource has been disposed