logstdmap.h
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C头文件 代码 · 共 57 行
H
57 行
// file : RolyPoly/LogStdMap.h
// author : Boris Kolpackov <boris@dre.vanderbilt.edu>
// cvs-id : LogStdMap.h,v 1.2 2003/12/22 01:44:37 wilson_d Exp
#ifndef LOG_STD_MAP_H
#define LOG_STD_MAP_H
#include <map>
template <typename RI, typename RV>
class Log
{
public:
typedef RI RecordIdType;
typedef RV RecordValueType;
private:
typedef
std::map <RecordIdType, RecordValueType>
Map_;
public:
class Duplicate {};
class NotFound {};
void
insert (RecordIdType const& ri, RecordValueType const& rv)
throw (Duplicate)
{
if (!map_.insert (std::make_pair (ri, rv)).second)
{
throw Duplicate ();
}
}
bool
contains (RecordIdType const& ri) const
{
return map_.count (ri) != 0;
}
RecordValueType const&
lookup (RecordIdType const& ri) const throw (NotFound)
{
typename Map_::const_iterator i = map_.find (ri);
if (i != map_.end ()) return i->second;
else throw NotFound ();
}
private:
Map_ map_;
};
#endif // LOG_STD_MAP_H
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?