[FIFO Cache实现】( List + hashtable | template | LRU )

 自动化测试

template < typename Contain >
//重载提取操作符<<
inline std::ostream&
operator<<( std::ostream& o, const std::optional< Contain >& object ){
	using namespace std::literals::string_literals;
	if( !object ) // optional< T >::operator bool()隐式转换
		return ( o << "null"s ); //cache未命中
	return ( o << object.value() );        //cache命中
}
//自动化测试
int main( void ){
	FIFOCache< std::ptrdiff_t, int > cache;
	//cache default capacity == 64
	int counter { 32 };
	//读写操作总次数
	srand( ( unsigned)time( nullptr ) );
	//随机数种子
	while( counter-- ){
		if( rand() % 101 <= 80  ){
		//80% load写操作
			int key { rand() % 64 };
			int value { rand() % 64 };
			std::printf("#put {key : %d, value: %d}...\n\n", key, value );
			cache.put({key,value});
		}else{
		//20% 读操作
			int key { rand() %64 };
			std::printf("#try-get {key: %d, value : ?}...\n\n", key );
			std::cout << "value:\t" << cache.get(key) << '\n';
		}
	}
	return 0;
}

运行结果

 

FIFOCache实现

#include <unordered_map>
#include <list>
#include <concepts>
#include <functional>
#include <optional>
#include <iostream>

template < class Key, class Value >
	requires requires{
		std::hash< Key >{}( std::declval< Key >() );
	}
class FIFOCache{
public:
	static constexpr std::size_t DEFAULT { 64 };
private:
	std::list< Key > cache;
	mutable std::unordered_map< Key, Value > hash;
	std::size_t capacity { DEFAULT };
public:
	typedef Key key_type;
	typedef Value value_type;
	typedef std::pair< Key, Value > pair_type;
	typedef std::optional< Value > return_type;
	FIFOCache( void ) noexcept = default;
	FIFOCache( const FIFOCache& ) noexcept = default;
	FIFOCache( FIFOCache&& ) noexcept = default;
	FIFOCache( std::size_t __capacity ) : capacity( __capacity ) { }
	[[discard]] return_type get( const Key& key )  const {
		if( !hash.count( key ) )
			return static_cast< std::optional< Value > >( std::nullopt );
		return return_type{ hash[key] };
	}
	void put( const pair_type& p ){
		auto [key, value] = p;
        if( hash.count(key)){
            hash[key] = value;
            return;
        }
        if(cache.size() == capacity){
            hash.erase(cache.front());
            cache.pop_front();
        }
        hash.insert(p);
        cache.push_back(key);
	}
};
template < typename Contain >
std::ostream& operator<<( std::ostream& o, const std::optional< Contain >& object ){
	using namespace std::literals::string_literals;
	if( !object ) return ( o << "null"s );
	return ( o << object.value() );
}

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

XNB's Not a Beginner

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值