我目前正在使用Boost的多索引来帮助跟踪数据包通过系统的次数。
每次系统触摸数据包时,其IP地址都会添加到以逗号分隔的字符串中。然后我查看该字符串,将其标记化并将找到的每个IP添加到多索引中。由于IP现在设置为唯一,因此不可能将相同的IP添加到多索引两次。那么应该发生的是与IP地址相关联的值应该递增,计算数据包通过同一IP的次数。
无论如何,我的问题在这里。当我使用像stl map这样的东西时,我会得到一个响应,让我知道由于地图中已经存在重复的密钥而无法添加密钥。 Boost的多指数是否提供类似的东西?我知道如果我尝试插入相同的IP,它将失败,但我怎么能告诉它失败?
以下是我当前代码的一部分:
// Multi-index handling
using boost::multi_index_container;
using namespace boost::multi_index;
struct pathlog
{
string hop;
int passedthru;
pathlog(std::string hop_,int passedthru_):hop(hop_),passedthru(passedthru_){}
friend std::ostream& operator<<(std::ostream& os,const pathlog& e)
{
os<<e.hop<<" "<<e.passedthru<<std::endl;
return os;
}
};
// structs for data
struct hop{};
struct passedthru{};
// multi-index container setup
typedef multi_index_container<
pathlog,
indexed_by<
ordered_unique<
tag<hop>, BOOST_MULTI_INDEX_MEMBER(pathlog,std::string,hop)>,
ordered_non_unique<
tag<passedthru>, BOOST_MULTI_INDEX_MEMBER(pathlog,int,passedthru)> >
> pathlog_set;
int disassemblepathlog(const string& str, pathlog_set& routecontainer, const string& delimiters = ","){
// Tokenizer (heavily modified) from http://oopweb.com/CPP/Documents/CPPHOWTO/Volume/C++Programming-HOWTO-7.html
// Skip delimiters at beginning.
string::size_type lastPos = str.find_first_not_of(delimiters, 0);
// Find first "non-delimiter".
string::size_type pos = str.find_first_of(delimiters, lastPos);
while (string::npos != pos || string::npos != lastPos)
{
// Found a token, add it to the vector.
routecontainer.insert(pathlog((str.substr(lastPos, pos - lastPos)),1)); // if this fails, I need to increment the counter!
// Skip delimiters. Note the "not_of"
lastPos = str.find_first_not_of(delimiters, pos);
// Find next "non-delimiter"
pos = str.find_first_of(delimiters, lastPos);
}
}
答案 0 :(得分:7)
您对insert的调用返回一个std :: pair&lt;迭代器,布尔&gt;。只有插入成功,bool才会成立。
请参阅http://www.boost.org/doc/libs/1_43_0/libs/multi_index/doc/reference/ord_indices.html#modifiers