pub struct SchedulerStat {
work_id_name_map: HashMap<TypeId, &'static str>,
work_counts: HashMap<TypeId, usize>,
work_counters: HashMap<TypeId, Vec<Vec<Box<dyn WorkCounter>>>>,
}Expand description
Merge and print the work-packet level statistics from all worker threads
Fields§
§work_id_name_map: HashMap<TypeId, &'static str>Map work packet type IDs to work packet names
work_counts: HashMap<TypeId, usize>Count the number of work packets executed for different types
work_counters: HashMap<TypeId, Vec<Vec<Box<dyn WorkCounter>>>>Collect work counters from work threads.
Two dimensional vectors are used, e.g.
[[foo_0, ..., foo_n], ..., [bar_0, ..., bar_n]].
The first dimension is for different types of work counters,
(foo and bar in the above example).
The second dimension if for work counters of the same type but from
different threads (foo_0 and bar_0 are from the same thread).
The order of insertion is determined by when SchedulerStat::merge is
called for each WorkerLocalStat.
We assume different threads have the same set of work counters
(in the same order).
Implementations§
source§impl SchedulerStat
impl SchedulerStat
sourcefn work_name(&self, name: &str) -> String
fn work_name(&self, name: &str) -> String
Extract the work-packet name from the full type name.
i.e. simplifies crate::scheduler::gc_work::SomeWorkPacket<Semispace> to SomeWorkPacket.
sourcepub fn harness_stat(&self) -> HashMap<String, String>
pub fn harness_stat(&self) -> HashMap<String, String>
Used during statistics printing at crate::memory_manager::harness_end
sourcepub fn merge<C>(&mut self, stat: &WorkerLocalStat<C>)
pub fn merge<C>(&mut self, stat: &WorkerLocalStat<C>)
Merge work counters from different worker threads
Trait Implementations§
source§impl Default for SchedulerStat
impl Default for SchedulerStat
source§fn default() -> SchedulerStat
fn default() -> SchedulerStat
Auto Trait Implementations§
impl Freeze for SchedulerStat
impl !RefUnwindSafe for SchedulerStat
impl Send for SchedulerStat
impl !Sync for SchedulerStat
impl Unpin for SchedulerStat
impl !UnwindSafe for SchedulerStat
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more