Add final annotations to some cache functions (#5156)

Summary:
cache functions heavily use virtual functions.
Add some "final" annotations to give compilers more information
to optimize. The compiler doesn't seem to take advantage of it
though. But it doesn't hurt.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/5156

Differential Revision: D14814837

Pulled By: siying

fbshipit-source-id: 4423f58eafc93f7dd3c5f04b02b5c993dba2ea94
main
Siying Dong 6 years ago committed by Facebook Github Bot
parent 8d1e52165d
commit 479c566771
  1. 4
      cache/clock_cache.cc
  2. 8
      cache/lru_cache.h

@ -234,7 +234,7 @@ struct CleanupContext {
}; };
// A cache shard which maintains its own CLOCK cache. // A cache shard which maintains its own CLOCK cache.
class ClockCacheShard : public CacheShard { class ClockCacheShard final : public CacheShard {
public: public:
// Hash map type. // Hash map type.
typedef tbb::concurrent_hash_map<CacheKey, CacheHandle*, CacheKey> HashTable; typedef tbb::concurrent_hash_map<CacheKey, CacheHandle*, CacheKey> HashTable;
@ -672,7 +672,7 @@ void ClockCacheShard::EraseUnRefEntries() {
Cleanup(context); Cleanup(context);
} }
class ClockCache : public ShardedCache { class ClockCache final : public ShardedCache {
public: public:
ClockCache(size_t capacity, int num_shard_bits, bool strict_capacity_limit) ClockCache(size_t capacity, int num_shard_bits, bool strict_capacity_limit)
: ShardedCache(capacity, num_shard_bits, strict_capacity_limit) { : ShardedCache(capacity, num_shard_bits, strict_capacity_limit) {

8
cache/lru_cache.h vendored

@ -165,7 +165,7 @@ class LRUHandleTable {
}; };
// A single shard of sharded cache. // A single shard of sharded cache.
class ALIGN_AS(CACHE_LINE_SIZE) LRUCacheShard : public CacheShard { class ALIGN_AS(CACHE_LINE_SIZE) LRUCacheShard final : public CacheShard {
public: public:
LRUCacheShard(size_t capacity, bool strict_capacity_limit, LRUCacheShard(size_t capacity, bool strict_capacity_limit,
double high_pri_pool_ratio, bool use_adaptive_mutex); double high_pri_pool_ratio, bool use_adaptive_mutex);
@ -284,7 +284,11 @@ class ALIGN_AS(CACHE_LINE_SIZE) LRUCacheShard : public CacheShard {
mutable port::Mutex mutex_; mutable port::Mutex mutex_;
}; };
class LRUCache : public ShardedCache { class LRUCache
#ifdef NDEBUG
final
#endif
: public ShardedCache {
public: public:
LRUCache(size_t capacity, int num_shard_bits, bool strict_capacity_limit, LRUCache(size_t capacity, int num_shard_bits, bool strict_capacity_limit,
double high_pri_pool_ratio, double high_pri_pool_ratio,

Loading…
Cancel
Save