用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::pair<int32_t,int32_t> 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做一些使迭代器失效的操作,比如说删除之类的,原因大家都知道

/**********************************************************************
 * 机械教条主义
 * 
 * From:          http://www.cnblogs.com/egmkang/
 * Email:         egmkang [at] 163.com
 * QQ Group:  20240291(慎入,可能没人打理) 
 * Weibo:
        http://weibo.com/egmkang
 * 
 **********************************************************************/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值