我正在存储以下一堆
struct Article {
std::string title;
unsigned db_id; // id field in MediaWiki database dump
};
在Boost.MultiIndex容器中,定义为
typedef boost::multi_index_container<
Article,
indexed_by<
random_access<>,
hashed_unique<tag<by_db_id>,
member<Article, unsigned, &Article::db_id> >,
hashed_unique<tag<by_title>,
member<Article, std::string, &Article::title> >
>
> ArticleSet;
现在我有两个迭代器,一个来自index<by_title>
,另一个来自index<by_id>
。将这些索引转换为容器的随机访问部分的最简单方法是什么,而不将数据成员添加到struct Article
?
答案 0 :(得分:6)
每个索引都支持使用iterator_to按值生成迭代器。如果在一个索引中已经有一个目标值的迭代器,则可以使用它来转换为另一个索引中的迭代器。
iterator iterator_to(const value_type& x);
const_iterator iterator_to(const value_type& x)const;
要转换为索引,您可以遵循random_access_index.hpp
中的模型:
iterator erase(iterator first,iterator last)
{
BOOST_MULTI_INDEX_CHECK_VALID_ITERATOR(first);
BOOST_MULTI_INDEX_CHECK_VALID_ITERATOR(last);
BOOST_MULTI_INDEX_CHECK_IS_OWNER(first,*this);
BOOST_MULTI_INDEX_CHECK_IS_OWNER(last,*this);
BOOST_MULTI_INDEX_CHECK_VALID_RANGE(first,last);
BOOST_MULTI_INDEX_RND_INDEX_CHECK_INVARIANT;
difference_type n=last-first;
relocate(end(),first,last);
while(n--)pop_back();
return last;
}
答案 1 :(得分:6)
iterator_to
是Boost中一个相对较新的函数(它自1.35起就存在)。使用默认索引时,它会添加一些语法糖。对于旧版本的Boost,函数project
是唯一的选择。您可以按如下方式使用project
:
ArticleSet x;
// consider we've found something using `by_db_id` index
ArticleSet::index_const_iterator<by_db_id>::type it =
x.get<by_db_id>().find( SOME_ID );
// convert to default index ( `random_access<>` )
ArticleSet::const_iterator it1 = x.project<0>( it );
// iterator_to looks like:
ArticleSet::const_iterator it11 = x.iterator_to( *it );
// convert to index tagged with `by_title` tag
ArticleSet::index_const_iterator<by_title>::type it2 = x.project<by_title>( it );
// iterator_to doen't look better in this case:
ArticleSet::index_const_iterator<by_title>::type it2 = x.get<by_title>().iterator_to( *it );
// etc.