Trait mm0_deepsize::DeepSizeOf[][src]

pub trait DeepSizeOf {
    fn deep_size_of_children(&self, context: &mut Context) -> usize;

    fn deep_size_of(&self) -> usize { ... }
fn deep_size_of_with(&self, context: &mut Context) -> usize { ... } }

A trait for measuring the size of an object and its children

In many cases this is just std::mem::size_of::<T>(), but if the struct contains a Vec, String, Box, or other allocated object or reference, then it is the size of the struct, plus the size of the contents of the object.

Required methods

fn deep_size_of_children(&self, context: &mut Context) -> usize[src]

Returns an estimation of the heap-managed storage of this object. This does not include the size of the object itself.

This is an estimation and not a precise result, because it doesn’t account for allocator’s overhead.

This is an internal function (this shouldn’t be called directly), and requires a Context to track visited references. Implementations of this function should only call deep_size_of_children, and not deep_size_of so that they reference tracking is not reset.

In all other cases, deep_size_of should be called instead of this function.

If a struct and all of its children do not allocate or have references, this method should return 0, as it cannot have any heap allocated children. There is a shortcut macro for this implementation, known_size_of, used like known_deep_size!(0, (), u32, u64); which generates the impls.

The most common way to use this method, and how the derive works, is to call this method on each of the structs members and sum the results, which works as long as all members of the struct implmeent DeepSizeOf.

To implement this for a collection type, you should sum the deep sizes of the items of the collection and then add the size of the allocation of the collection itself. This can become much more complicated if the collection has multiple seperate allocations.

Here is an example from the implementation of DeepSizeOf for Vec<T>

impl<T> DeepSizeOf for std::vec::Vec<T> where T: DeepSizeOf {
    fn deep_size_of_children(&self, context: &mut Context) -> usize {
        // Size of heap allocations for each child
        self.iter().map(|child| child.deep_size_of_children(context)).sum()
         + self.capacity() * std::mem::size_of::<T>()  // Size of Vec's heap allocation
    }
}
Loading content...

Provided methods

fn deep_size_of(&self) -> usize[src]

Returns an estimation of a total size of memory owned by the object, including heap-managed storage.

This is an estimation and not a precise result, because it doesn’t account for allocator’s overhead.

fn deep_size_of_with(&self, context: &mut Context) -> usize[src]

Returns an estimation of a total size of memory owned by the object, including heap-managed storage.

Loading content...

Implementations on Foreign Types

impl<T: DeepSizeOf> DeepSizeOf for Vec<T>[src]

impl<T: DeepSizeOf> DeepSizeOf for VecDeque<T>[src]

impl<K: DeepSizeOf, V: DeepSizeOf, S> DeepSizeOf for HashMap<K, V, S>[src]

impl<T: DeepSizeOf, S> DeepSizeOf for HashSet<T, S>[src]

impl<K: Ord + DeepSizeOf, V: DeepSizeOf> DeepSizeOf for BTreeMap<K, V>[src]

impl<T: DeepSizeOf + ?Sized> DeepSizeOf for Box<T>[src]

impl<T: DeepSizeOf + ?Sized> DeepSizeOf for Arc<T>[src]

impl<T: DeepSizeOf + ?Sized> DeepSizeOf for Rc<T>[src]

impl<T: DeepSizeOf> DeepSizeOf for [T][src]

impl<O: DeepSizeOf, T: ?Sized> DeepSizeOf for OwningRef<O, T>[src]

impl DeepSizeOf for u8[src]

impl DeepSizeOf for u16[src]

impl DeepSizeOf for u32[src]

impl DeepSizeOf for u64[src]

impl DeepSizeOf for usize[src]

impl DeepSizeOf for i8[src]

impl DeepSizeOf for i16[src]

impl DeepSizeOf for i32[src]

impl DeepSizeOf for i64[src]

impl DeepSizeOf for isize[src]

impl DeepSizeOf for bool[src]

impl DeepSizeOf for char[src]

impl DeepSizeOf for f32[src]

impl DeepSizeOf for f64[src]

impl DeepSizeOf for ()[src]

impl DeepSizeOf for str[src]

impl DeepSizeOf for AtomicBool[src]

impl DeepSizeOf for AtomicIsize[src]

impl DeepSizeOf for AtomicUsize[src]

impl<T: ?Sized> DeepSizeOf for &T[src]

impl<T> DeepSizeOf for Cell<T>[src]

impl<T> DeepSizeOf for Weak<T>[src]

impl<T> DeepSizeOf for MaybeUninit<T>[src]

impl<T: ?Sized> DeepSizeOf for PhantomData<T>[src]

impl DeepSizeOf for dyn Error + Send + Sync[src]

impl<T> DeepSizeOf for Sender<T>[src]

impl DeepSizeOf for String[src]

impl<T: DeepSizeOf> DeepSizeOf for Option<T>[src]

impl<R: DeepSizeOf, E: DeepSizeOf> DeepSizeOf for Result<R, E>[src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 0][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 1][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 2][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 3][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 4][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 5][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 6][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 7][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 8][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 9][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 10][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 11][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 12][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 13][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 14][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 15][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 16][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 17][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 18][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 19][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 20][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 21][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 22][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 23][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 24][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 25][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 26][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 27][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 28][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 29][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 30][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 31][src]

impl<T: DeepSizeOf> DeepSizeOf for [T; 32][src]

impl<A: DeepSizeOf> DeepSizeOf for (A,)[src]

impl<A: DeepSizeOf, B: DeepSizeOf> DeepSizeOf for (A, B)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf> DeepSizeOf for (A, B, C)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf> DeepSizeOf for (A, B, C, D)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf> DeepSizeOf for (A, B, C, D, E)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf, F: DeepSizeOf> DeepSizeOf for (A, B, C, D, E, F)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf, F: DeepSizeOf, G: DeepSizeOf> DeepSizeOf for (A, B, C, D, E, F, G)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf, F: DeepSizeOf, G: DeepSizeOf, H: DeepSizeOf> DeepSizeOf for (A, B, C, D, E, F, G, H)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf, F: DeepSizeOf, G: DeepSizeOf, H: DeepSizeOf, I: DeepSizeOf> DeepSizeOf for (A, B, C, D, E, F, G, H, I)[src]

impl<A: DeepSizeOf, B: DeepSizeOf, C: DeepSizeOf, D: DeepSizeOf, E: DeepSizeOf, F: DeepSizeOf, G: DeepSizeOf, H: DeepSizeOf, I: DeepSizeOf, J: DeepSizeOf> DeepSizeOf for (A, B, C, D, E, F, G, H, I, J)[src]

impl DeepSizeOf for PathBuf[src]

impl DeepSizeOf for BigUint[src]

impl DeepSizeOf for BigInt[src]

impl DeepSizeOf for Url[src]

impl<T: DeepSizeOf> DeepSizeOf for RefCell<T>[src]

impl<T: DeepSizeOf> DeepSizeOf for Mutex<T>[src]

impl<T: DeepSizeOf> DeepSizeOf for Mutex<T>[src]

impl<T: DeepSizeOf> DeepSizeOf for Arena<T>[src]

impl DeepSizeOf for Mmap[src]

Loading content...

Implementors

Loading content...