为包含指针的关联容器指定比较类型

Effective STL读书笔记

今天看了一条,写下来当做笔记,其实挺好理解的,也挺简单的

为包含指针的关联容器指定比较类型

我们知道,当我们创建一个关联容器时,比如set或者map,它会要求 我们指定一个比较函数子类。如果我们不指定就会采用默认的比较函数子类,当然在某些情况下会产生错误。

比如下面的代码

int main()

{

      typedefset<string *>  StringSetT;

      StringSetTstrSet;

      strSet.insert(newstring("a"));

      strSet.insert(newstring("c"));

      strSet.insert(newstring("b"));

      StringSetT::iteratorit=strSet.begin();

      for(;it!=strSet.end();++it)

            cout<<**it<<'\t';

      return0;

}


输出的结果并不是我们想要的按字母顺序输出,因为采用的是set的默认比较函数子类less<string*>  插入时其实是按指针所存的地址的大小来比较的。

 

所以如果 我们想要采用上述字符串按照字母顺序输出,就必须重新定义子类的比较函数子类

int main()

{

typedefset<string *,Stringcmp> stringSetT;

stringSetT sSet;

sSet.insert(newstring("a"));

sSet.insert(newstring("c"));

sSet.insert(newstring("b"));

stringSetT::iteratorit=sSet.begin();

for(;it!=sSet.end();++it)

cout<<**it<<'\t';     

}

输出结果如下:

 

我们为什么要写一个函数子类,而不是只用一个函数呢?这是因为set创建类型时只接收的是一个类型,所以我们必须声明成一个类。

在这我们可以写一个通用的模板函数

struct Strcmp

{

      template<typenameptrType>

      booloperator()(const ptrType left,const ptrType right)

      {

            return(*left) < (*right);

      }

};

 

直接这么使用,只要是指针类就可以使用

typedef set<string *,Strcmp >stringSetT;

关于这个还有个问题没有解决,有时间再说吧,我要下班啦,哈哈哈。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值