baidu

[boost]用BOOST_FOREACH简化遍历操作

成天写迭代器,写的手指都疼,BOOST_FOREACH可以方便的遍历STL容器.

只需要头文件:

#include <boost/foreach.hpp>

然后遍历容器vector/list/set/deque/stack/queue都是类似的:

vector<int32_t> _v;
BOOST_FOREACH(int32_t value,_v)
{
//这里就可以访问value
}

同时元素还支持引用,const,比如上面代码还可以写成:

vector<int32_t> _v;

BOOST_FOREACH(int32_t
& value,_v)
{
//这里就可以修改/访问value
}

如果元素内容是结构体之类,引用可以防止拷贝~~

对于map的访问有一点特殊,因为map的元素是std::pair<T1,T2>,所以需要写成这样:

std::map<int32_t,int32_t> _map;
typedef const std::map<int32_t, int32_t>::value_type const_pair;
BOOST_FOREACH(const_pair
& node,_map)
{
//这里就可以访问node的元素
int32_t key = node.first;
int32_t value
= node.second;
}

multimap么暂时还没用过,不过相信也是类似的...感觉multimap有一点类似于map<key,set<value> > :-D

BOOST_FOREACH是正向的迭代,逆向的是BOOST_REVERSE_FOREACH

另外,不能再scope做一些使迭代器失效的操作,比如说删除之类的,原因大家都知道

posted @ 2011-05-14 13:46  egmkang  阅读(15564)  评论(0编辑  收藏  举报