From f5df8e39c75c82a70ab334fe246ed8107cbeeede Mon Sep 17 00:00:00 2001 From: Michael Davis Date: Thu, 5 Sep 2024 18:15:59 -0400 Subject: [PATCH] Add more detailed notes on memory savings from boxed slices --- README.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 7679b9a..21c1ec6 100644 --- a/README.md +++ b/README.md @@ -78,7 +78,9 @@ There are a few key data structures that power Spellbook and make lookup fast. ##### Boxed slices -By default Spellbook prefers boxed slices (`Box<[T]>`) and boxed strs (`Box`) rather than their mutable counterparts `Vec` and `String`. Boxed slices are basically the same but are immutable once created. They also discard any excess capacity and don't need to track capacity, saving a very small amount of memory per instance. That memory adds up though across all of the words in the dictionary. For some quick napkin math, this saves at least 392,464 bytes for the word list in `en_US` on a 64 bit target: 4 bytes for the stem's capacity field and another 4 bytes for the flag set's capacity field for each of the 49,058 words in `en_US.dic`. +By default Spellbook prefers boxed slices (`Box<[T]>`) and boxed strs (`Box`) rather than their mutable counterparts `Vec` and `String`. Boxed slices can be used the same but are immutable once created. You can push to a `Vec` but not a `Box<[T]>` for example. They also discard any excess capacity and don't need to track capacity, saving a very small amount of memory per instance. That memory adds up though across all of the words in the dictionary. + +For some quick napkin math, this saves at least 392,464 bytes for the word list in `en_US` on a 64 bit target: 4 bytes for the stem's capacity field and another 4 bytes for the flag set's capacity field for each of the 49,058 words in `en_US.dic`. In practice we can measure the difference with Valgrind's [DHAT](https://valgrind.org/docs/manual/dh-manual.html) tool. If we switch Spellbook's `WordList` type to store `String`s and `Vec`s instead of `Box`s and `Box<[Flag]>`s, I see the total heap bytes allocated in a run of `./target/debug/examples/check hello` rise from 3MB to 4MB. ##### Flag sets