Skip to main content

ConcurrentRuntime

Struct ConcurrentRuntime 

pub struct ConcurrentRuntime {
    channel_sender: Sender<GCArc<GCDatapointValue>>,
    concurrent_threads: u16,
    thread_ctx: ThreadCtx,
    threads: Vec<JoinHandle<()>>,
}
Expand description

Concurrent runtime used to distribute messages to the subscribers using multiple threads.

Fields§

§channel_sender: Sender<GCArc<GCDatapointValue>>§concurrent_threads: u16§thread_ctx: ThreadCtx§threads: Vec<JoinHandle<()>>

Implementations§

§

impl ConcurrentRuntime

pub fn new( datapoint_mapping: Arc<RwLock<DatapointMapping>>, concurrent_threads: u16, queue_size: usize, ) -> Self

pub fn get_mapping(&self) -> &RwLock<DatapointMapping>

Returns a reference to the asynchronous subscriber mapping.

pub fn get_sender_channel(&self) -> Sender<GCArc<GCDatapointValue>>

Returns a reference to the sender channel.

pub fn start(&mut self)

Starts the message broker and distributes the messages to the subscribers using multiple threads.

Trait Implementations§

§

impl Drop for ConcurrentRuntime

§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.