Struct mmtk::scheduler::stat::SchedulerStat
source · 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 !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>
. Box<dyn Any>
can
then be further downcast
into Box<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>
. Rc<Any>
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.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