Boost组件multi_index_container实例(续4)

本博客http://blog.csdn.net/livelylittlefish 贴 出作 者(三二一@小鱼)相关研究、学习内容所做的笔记,欢迎广大朋友指正!

 

1. 引子

 

实例 ( 3) 的基础上,将 print _container free _container find _container 模板化。

 

2. 修改 print _container free _container find _container 函数

 

//a template to print a container

template <typename Tag , typename MultiIndexContainer >

void print_container(const MultiIndexContainer& container)

{

    //obtain a reference to the index tagged by Tag

    const typename boost::multi_index::index<MultiIndexContainer , Tag >::type& indexSet = get<Tag >(container);

 

    typedef typename MultiIndexContainer ::value_type value_type;

 

    //dump the elements of the index to cout

    std::copy(indexSet.begin(), indexSet.end(), std::ostream_iterator(cout));

}

 

3. 代码及运行结果

 

multiindexcontainer4.cpp

运行结果如下:

(1, 1, 1) - (10, 100)

(1, 1, 2) - (20, 200)

(1, 1, 3) - (30, 300)

(1, 2, 1) - (40, 400)

(1, 2, 2) - (50, 500)

(1, 2, 3) - (60, 600)

(1, 3, 1) - (70, 700)

(1, 3, 2) - (80, 800)

(1, 3, 3) - (90, 900)

(2, 1, 1) - (110, 1000)

(2, 1, 2) - (220, 2000)

(2, 1, 3) - (330, 3000)

(2, 2, 1) - (440, 4000)

(2, 2, 2) - (550, 5000)

(2, 2, 3) - (660, 6000)

(2, 3, 1) - (770, 7000)

(2, 3, 2) - (880, 8000)

(2, 3, 3) - (990, 9000)

 

(1, 1, 1) - (10, 100), found

(1, 1, 2) - (20, 200), found

(1, 1, 3) - (30, 300), found

(1, 2, 1) - (40, 400), found

(1, 2, 2) - (50, 500), found

(1, 2, 3) - (60, 600), found

(1, 3, 1) - (70, 700), found

(1, 3, 2) - (80, 800), found

(1, 3, 3) - (90, 900), found

(2, 1, 1) - (110, 1000), found

(2, 1, 2) - (220, 2000), found

(2, 1, 3) - (330, 3000), found

(2, 2, 1) - (440, 4000), found

(2, 2, 2) - (550, 5000), found

(2, 2, 3) - (660, 6000), found

(2, 3, 1) - (770, 7000), found

(2, 3, 2) - (880, 8000), found

(2, 3, 3) - (990, 9000), found

 

(1, 1, 1) - (10, 100), destructed

(1, 1, 2) - (20, 200), destructed

(1, 1, 3) - (30, 300), destructed

(1, 2, 1) - (40, 400), destructed

(1, 2, 2) - (50, 500), destructed

(1, 2, 3) - (60, 600), destructed

(1, 3, 1) - (70, 700), destructed

(1, 3, 2) - (80, 800), destructed

(1, 3, 3) - (90, 900), destructed

(2, 1, 1) - (110, 1000), destructed

(2, 1, 2) - (220, 2000), destructed

(2, 1, 3) - (330, 3000), destructed

(2, 2, 1) - (440, 4000), destructed

(2, 2, 2) - (550, 5000), destructed

(2, 2, 3) - (660, 6000), destructed

(2, 3, 1) - (770, 7000), destructed

(2, 3, 2) - (880, 8000), destructed

(2, 3, 3) - (990, 9000), destructed


Technorati 标签: Boost , multi_index , multi_index_container

Boost库中的multi_index是一种强大的工具,它允许你在STL容器(如map、set等)中创建多个索引视图,每个索引对应于不同的排序标准或访问模式。以下是使用boost::multi_index的基本步骤: 1. **包含头文件**: 首先,你需要包含`<boost/multi_index_container.hpp>`和需要的单个或多索引的头文件。 ```cpp #include <boost/multi_index_container.hpp> #include <boost/multi_index/member.hpp> ``` 2. **声明multi_index_container**: 定义一个multi_index_container,指定存储的数据类型(例如std::string),以及你想要创建的索引类型。你可以选择primary_index作为默认索引,也可以添加secondary_indices。 ```cpp using index_type = boost::multi_index::ordered_set<std::string>; typedef boost::multi_index_container< std::pair<std::string, int>, // 存储的数据类型 boost::multi_index::indexed_by< boost::multi_index::primary_index<>, boost::multi_index::hashed_non_unique<index_type> > >; ``` 这里`hashed_non_unique`表示元素是唯一的,但是查找速度较快(因为使用哈希表)。 3. **创建实例**: 实例multi_index_container,并为其分配内存。 ```cpp index_type my_index; ``` 4. **插入数据**: 使用insert函数将数据加入容器,并关联到适当的索引。 ```cpp my_index.insert({"key1", value1}); ``` 5. **通过索引访问数据**: 可以通过索引来检索数据,如primary_index用于快速查找,而index_type可以用于按照自定义键值进行搜索。 ```cpp // Primary index search auto it = my_index.begin(); for (; it != my_index.end(); ++it) { std::cout << "Primary Index: " << it->first << ", Value: " << it->second << '\n'; } // Indexed by search auto search_result = my_index.find("key1"); if (search_result != my_index.end()) { std::cout << "Hashed Search: " << search_result->first << ", Value: " << search_result->second << '\n'; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值