【转载】std::map的一些注意点

转载:http://www.cnblogs.com/marco/archive/2009/08/19/1549918.html

std::map是一个很常用的标准容器,采用红黑树或者平衡二叉树来储存节点内容,具有对数复杂度的插入时间和查找时间。这里简单说下它的一些值得注意的关注点。

 
插入:
std::map<int, std::string> str_map;
str_map.insert ( std::pair<const int, std::string>(2, "bb") );      //没有转型操作
str_map.insert ( std::pair<int, std::string>(2, "bb") );     //需要转型成std::pair<const int, std::string>再进行插入
str_map.insert ( std::make_pair(3, "cc") );          //同上,需要转型
str_map.insert ( std::map<int, std::string>::value_type ( 4 , "dd" ) );      //没有转型操作
还有一种方法是通过索引器[]去直接插入,这种方法在下边再讨论。
 
删除:
一种很常见的错误是:
for ( map<int, string>::iterator it = str_map.begin(); it!=str_map.end(); it++ ) {
 if ( some_condition )
 str_map.erase(it);
}
删除操作会使it乱掉,再使用it++就出错了。正确的做法是:
for ( map<int, string>::iterator it = str_map.begin(); it!=str_map.end();  ) {
 if ( some_condition ) {
 str_map.erase(it++);
 } else {
 it++;
 }
}
 
索引:
str_map[5] = "ee";
这条语句实际上是分两个步骤执行的:
先在str_map[5]的地方构造一个空string,然后通过str_map[5]返回这个string的reference;
然后调用这个空string的assignment运算符,把"ee"赋给它。
因此,这样写要比直接insert效率低些。
索引还有一个问题是需要注意的:
map<int, string> m;
cout<<m.size()<<endl; // output: 0
if ( m[4] == "aa" )
 some_operation();
cout<<m.size()<<endl; //output: 1
这里m[4]已经指向了一个构造好了的空string
 
function object:
在std::mem_fun的帮助下,vector等容器可以很容易地使用find_if等泛型算法,比如:
class X {
public:
 bool condition();
};
vector<X> vx;
....
vector<X>::iterator it = std::find_if ( vx.begin(), vx.end(), std::mem_fun(&X::condition) );
由于map::iterator指向的是std::pair,所以要使用这些算法大部分时候就只好自己手写相应的function object了。
但借助boost lambda库的帮助,我们就可以省去自己写function object的麻烦了:
#include <boost/lambda/bind.hpp>
#include <boost/lambda/lambda.hpp>
using boost::lambda::bind; 
std::map<int, X> mx;
....
std::map<int, X>::iterator it = find_if ( mx.begin(), mx.end(),
 bind ( &X::condition, bind(&std::map<int, X>::value_type::second, _1) ) );

转载于:https://www.cnblogs.com/edwardlost/archive/2010/09/09/1822484.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值