这两天在看c++ STL模板库,被函数适配器折磨得死去活来的,查阅了很多资料,终于有点小小的见解。
我们现在想做的事情是找出vector中大于5的数的个数,我们当然会立刻想到用for循环来写,比如下面的方式
for(std::vector<int>::iterator ite = vec.begin(), ite != vec.end(), ++ ite)
{
if(5< *ite)
++count;
}
这样做是正确的,但是当我们学了泛型算法,我们就会找到更为合适的方法来达到这个目的,并且能保证正确性和简洁性,比如
count_if,count_if需要传入一个函数对象,但问题在于我们还要传入一参数5,让容器的所有数都和5做比较,这个时候函数对象适
配器就隆重登场了,让我们来看看,它是怎么工作得。
首先我将STL中的binder1st的源码中最重要的部分摆出来,稍微做一些修改,注意完全是为了我们好理解。
binder1st:

本文介绍了C++ STL中的函数适配器binder1st和binder2nd,通过实例展示了如何使用它们来简化代码,特别是与泛型算法如count_if配合时。文章通过源码分析和示例程序解释了binder1st如何将固定值与运算符结合,以及binder2nd的类似工作原理。
最低0.47元/天 解锁文章
549

被折叠的 条评论
为什么被折叠?



