expand on singe-item caches

This commit is contained in:
Damian Gryski 2018-11-25 07:28:36 -08:00
parent 7a62bf2351
commit 639e13fb8f

View File

@ -315,10 +315,14 @@ Ideas for augmenting your data structure:
* Over the wire, the network + cost of serialization will hurt. * Over the wire, the network + cost of serialization will hurt.
* In-process caches, but now you need to worry about expiration and added GC pressure * In-process caches, but now you need to worry about expiration and added GC pressure
* Even a single item can help (logfile time parse example).
TODO: "cache" might not even be key-value, just a pointer to where you were A cache saves information you've just spent time computing in the hopes that
working. This can be as simple as a "search finger" you'll be able to reuse it again soon and save the computation time. A cache
doesn't need to be complex. Even storing a single item -- the most recently
seen query/response -- can be a big win. This "single item" idea can be extended
to a "search finger", where you store an pointer to where your just were in your
data structure on the assumption it's a good starting point for your next
operation.
These are all clear examples of "do less work" at the data structure level. These are all clear examples of "do less work" at the data structure level.
They all cost space. Most of the time if you're optimizing for CPU, your They all cost space. Most of the time if you're optimizing for CPU, your