object Balance

Fan-out the stream to several streams. Each upstream element is emitted to the first available downstream consumer. It will not shutdown until the subscriptions for at least two downstream subscribers have been established.

Emits when any of the outputs stops backpressuring; emits the element to the first available output

Backpressures when all of the outputs backpressure

Completes when upstream completes

Cancels when If eagerCancel is enabled: when any downstream cancels; otherwise: when all downstreams cancel

Source
Graph.scala
Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Balance
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native() @HotSpotIntrinsicCandidate()
  6. def create[T](clazz: Class[T], outputCount: Int, waitForAllDownstreams: Boolean, eagerCancel: Boolean): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type.

    Create a new Balance operator with the specified input type.

    clazz

    a type hint for this method

    outputCount

    number of output ports

    waitForAllDownstreams

    if true it will not start emitting elements to downstream outputs until all of them have requested at least one element

    eagerCancel

    if true, balance cancels upstream if any of its downstreams cancel, if false, when all have cancelled.

  7. def create[T](clazz: Class[T], outputCount: Int, waitForAllDownstreams: Boolean): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type, eagerCancel is false.

    Create a new Balance operator with the specified input type, eagerCancel is false.

    clazz

    a type hint for this method

    outputCount

    number of output ports

    waitForAllDownstreams

    if true it will not start emitting elements to downstream outputs until all of them have requested at least one element

  8. def create[T](clazz: Class[T], outputCount: Int): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type, both waitForAllDownstreams and eagerCancel are false.

    Create a new Balance operator with the specified input type, both waitForAllDownstreams and eagerCancel are false.

    clazz

    a type hint for this method

    outputCount

    number of output ports

  9. def create[T](outputCount: Int): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type, both waitForAllDownstreams and eagerCancel are false.

    Create a new Balance operator with the specified input type, both waitForAllDownstreams and eagerCancel are false.

    outputCount

    number of output ports

  10. def create[T](outputCount: Int, waitForAllDownstreams: Boolean, eagerCancel: Boolean): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type.

    Create a new Balance operator with the specified input type.

    outputCount

    number of output ports

    waitForAllDownstreams

    if true it will not start emitting elements to downstream outputs until all of them have requested at least one element

    eagerCancel

    if true, balance cancels upstream if any of its downstreams cancel, if false, when all have cancelled.

  11. def create[T](outputCount: Int, waitForAllDownstreams: Boolean): Graph[UniformFanOutShape[T, T], NotUsed]

    Create a new Balance operator with the specified input type, eagerCancel is false.

    Create a new Balance operator with the specified input type, eagerCancel is false.

    outputCount

    number of output ports

    waitForAllDownstreams

    if true it will not start emitting elements to downstream outputs until all of them have requested at least one element

  12. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  13. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  14. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  15. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  16. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  17. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  18. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  19. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  20. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  21. def toString(): String
    Definition Classes
    AnyRef → Any
  22. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  23. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()
  24. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])

Deprecated Value Members

  1. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable]) @Deprecated @Deprecated
    Deprecated

Inherited from AnyRef

Inherited from Any

Ungrouped