LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
LSST Data Management Base Package
|
Cache of most recently used values. More...
#include <Cache.h>
Public Member Functions | |
Cache (std::size_t maxElements=0) | |
Ctor. | |
Cache (Cache const &)=default | |
Cache (Cache &&)=default | |
Cache & | operator= (Cache const &)=default |
Cache & | operator= (Cache &&)=default |
~Cache ()=default | |
Dtor. | |
template<typename Generator > | |
Value | operator() (Key const &key, Generator func) |
Lookup or generate a value. | |
Value | operator[] (Key const &key) |
void | add (Key const &key, Value const &value) |
Add a value to the cache. | |
std::size_t | size () const |
Return the number of values in the cache. | |
std::vector< Key > | keys () const |
Return all keys in the cache, most recent first. | |
bool | contains (Key const &key) |
Does the cache contain the key? | |
std::optional< Value > | get (Key const &key) |
Return the cached value if it exists. | |
std::size_t | capacity () const |
Return the capacity of the cache. | |
void | reserve (std::size_t maxElements) |
Change the capacity of the cache. | |
void | flush () |
Empty the cache. | |
Cache (std::size_t maxElements=0) | |
Ctor. | |
Cache (Cache const &)=default | |
Cache (Cache &&)=default | |
Cache & | operator= (Cache const &)=default |
Cache & | operator= (Cache &&)=default |
~Cache ()=default | |
Dtor. | |
template<typename Generator > | |
Value | operator() (Key const &key, Generator func) |
Lookup or generate a value. | |
Value | operator[] (Key const &key) |
void | add (Key const &key, Value const &value) |
Add a value to the cache. | |
std::size_t | size () const |
Return the number of values in the cache. | |
std::vector< Key > | keys () const |
Return all keys in the cache, most recent first. | |
bool | contains (Key const &key) |
Does the cache contain the key? | |
std::optional< Value > | get (Key const &key) |
Return the cached value if it exists. | |
std::size_t | capacity () const |
Return the capacity of the cache. | |
void | reserve (std::size_t maxElements) |
Change the capacity of the cache. | |
void | flush () |
Empty the cache. | |
Cache of most recently used values.
This object stores the most recent maxElements
values, where maxElements
is set in the constructor. Objects (of type Value
) are stored by a key (of type Key
; hence the need to provide a KeyHash
and KeyPred
), and the class presents a dict-like interface. Objects may be added to (add
) and retrieved from (operator[]
) the cache. For ease of use, an interface (operator()
) is also provided that will check the cache for an existing key, and if the key is not present, generate it with a function provided by the user.
Value
and Key
must be copyable.Cache.h
) should generally only be included in source files, not other header files, because you probably don't want all of the boost::multi_index
includes in your header. We suggest you se the CacheFwd.h
file in your header instead, and hold the Cache
as a std::unique_ptr
.lsst/cpputils/python/Cache.h
.
|
inline |
Ctor.
The maximum number of elements may be zero (default), in which case the cache is permitted to grow without limit.
Definition at line 85 of file Cache.h.
|
default |
|
default |
|
default |
Dtor.
|
inline |
Ctor.
The maximum number of elements may be zero (default), in which case the cache is permitted to grow without limit.
Definition at line 85 of file Cache.h.
|
default |
|
default |
|
default |
Dtor.
void lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::add | ( | Key const & | key, |
Value const & | value ) |
Add a value to the cache.
If the key is already in the cache, the existing value will be promoted to the most recently used value.
Definition at line 318 of file Cache.h.
void lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::add | ( | Key const & | key, |
Value const & | value ) |
Add a value to the cache.
If the key is already in the cache, the existing value will be promoted to the most recently used value.
|
inline |
|
inline |
|
inline |
|
inline |
void lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::flush | ( | ) |
Empty the cache.
Definition at line 336 of file Cache.h.
void lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::flush | ( | ) |
Empty the cache.
|
inline |
Return the cached value if it exists.
If the key is in the cache, it will be promoted to the most recently used value.
|
inline |
Return the cached value if it exists.
If the key is in the cache, it will be promoted to the most recently used value.
std::vector< Key > lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::keys | ( | ) | const |
Return all keys in the cache, most recent first.
Definition at line 326 of file Cache.h.
std::vector< Key > lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::keys | ( | ) | const |
Return all keys in the cache, most recent first.
Value lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::operator() | ( | Key const & | key, |
Generator | func ) |
Lookup or generate a value.
If the key is in the cache, the corresponding value is returned. Otherwise, a value is generated by the provided function which is cached and returned. Thus, the (expensive) Generator
function only fires if the corresponding value is not already cached.
The Generator
function signature should be:
Value func(Key const& key);
Given the possibility of lambdas, we could have made the required function signature so that it took no arguments. However, it's possible the user has some function that produces a value when given a key, so chose to adopt that signature; any other signature would likely require use of a lambda always.
Value lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::operator() | ( | Key const & | key, |
Generator | func ) |
Lookup or generate a value.
If the key is in the cache, the corresponding value is returned. Otherwise, a value is generated by the provided function which is cached and returned. Thus, the (expensive) Generator
function only fires if the corresponding value is not already cached.
The Generator
function signature should be:
Value func(Key const& key);
Given the possibility of lambdas, we could have made the required function signature so that it took no arguments. However, it's possible the user has some function that produces a value when given a key, so chose to adopt that signature; any other signature would likely require use of a lambda always.
|
default |
|
default |
|
default |
|
default |
Value lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::operator[] | ( | Key const & | key | ) |
Definition at line 308 of file Cache.h.
Value lsst::cpputils::Cache< Key, Value, KeyHash, KeyPred >::operator[] | ( | Key const & | key | ) |
|
inline |
|
inline |
|
inline |
|
inline |