zoukankan      html  css  js  c++  java
  • [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做一些使迭代器失效的操作,比如说删除之类的,原因大家都知道

  • 相关阅读:
    rails时间问题
    stringify_keys 和symbolize_keys
    thritf
    Nginx负载均衡反向代理
    CentOS 7 yum 安装 Nginx
    CentOS 7安装与配置Tomcat8
    CentOS 7安装与配置JDK8
    系统数据字典模块设计
    mysql视图
    阿里云maven中央仓库
  • 原文地址:https://www.cnblogs.com/egmkang/p/2046205.html
Copyright © 2011-2022 走看看