[−][src]Struct futures_intrusive::channel::GenericChannel
A channel which can be used to exchange values of type T
between
concurrent tasks.
A
represents the backing buffer for a Channel. E.g. a channel which
can buffer up to 4 u32 values can be created via:
let channel: LocalChannel<i32, [i32; 4]> = LocalChannel::new();
Tasks can receive values from the channel through the receive
method.
The returned Future will get resolved when a value is sent into the channel.
Values can be sent into the channel through send
.
The returned Future will get resolved when the value has been stored
inside the channel.
Methods
impl<MutexType: RawMutex, T, A> GenericChannel<MutexType, T, A> where
A: RingBuf<Item = T>,
[src]
A: RingBuf<Item = T>,
pub fn new() -> Self
[src]
Creates a new Channel, utilizing the default capacity that
the RingBuffer in A
provides.
pub fn with_capacity(capacity: usize) -> Self
[src]
Creates a new Channel, which has storage for a capacity
items.
Depending on the utilized RingBuf
type, the capacity argument might
be ignored and the default capacity might be utilized.
pub fn send(&self, value: T) -> ChannelSendFuture<MutexType, T>
[src]
Returns a future that gets fulfilled when the value has been written to the channel. If the channel gets closed while the send is in progress, sending the value will fail, and the future will deliver the value back.
pub fn try_send(&self, value: T) -> Result<(), TrySendError<T>>
[src]
Attempt to send the value without waiting.
This operation is not supported for unbuffered channels and will
panic if the capacity of the RingBuf
is zero. The reason for this is
that the actual value transfer on unbuffered channels always happens
when a receiving task copies the value out of the sending task while it
is waiting. If the sending task does not wait, the value can not be
transferred. Since this method can therefore never yield a reasonable
result with unbuffered channels, it panics in order to highlight the
use of an inappropriate API.
pub fn receive(&self) -> ChannelReceiveFuture<MutexType, T>
[src]
Returns a future that gets fulfilled when a value is written to the channel.
If the channels gets closed, the future will resolve to None
.
pub fn try_receive(&self) -> Result<T, TryReceiveError>
[src]
Attempt to receive a value of the channel without waiting.
pub fn stream(&self) -> ChannelStream<MutexType, T, A>
[src]
Returns a stream that will receive values from this channel.
This stream does not yield None
when the channel is empty,
instead it yields None
when it is terminated.
pub fn close(&self) -> CloseStatus
[src]
Closes the channel. All pending and future send attempts will fail. Receive attempts will continue to succeed as long as there are items stored inside the channel. Further attempts will fail.
Trait Implementations
impl<MutexType: RawMutex, T, A> Debug for GenericChannel<MutexType, T, A> where
A: RingBuf<Item = T>,
[src]
A: RingBuf<Item = T>,
impl<MutexType: RawMutex + Send, T: Send, A> Send for GenericChannel<MutexType, T, A> where
A: RingBuf<Item = T> + Send,
[src]
A: RingBuf<Item = T> + Send,
impl<MutexType: RawMutex + Sync, T: Send, A> Sync for GenericChannel<MutexType, T, A> where
A: RingBuf<Item = T>,
[src]
A: RingBuf<Item = T>,
Auto Trait Implementations
impl<MutexType, T, A> !RefUnwindSafe for GenericChannel<MutexType, T, A>
impl<MutexType, T, A> Unpin for GenericChannel<MutexType, T, A> where
A: Unpin,
MutexType: Unpin,
A: Unpin,
MutexType: Unpin,
impl<MutexType, T, A> UnwindSafe for GenericChannel<MutexType, T, A> where
A: UnwindSafe,
MutexType: UnwindSafe,
T: RefUnwindSafe,
A: UnwindSafe,
MutexType: UnwindSafe,
T: RefUnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,