关闭

bind1st bind2nd的使用

标签: functorlessvector
429人阅读 评论(0) 收藏 举报
分类:


bind1st和bind2nd函数用于将一个二元算子(binary functor,bf)转换成一元算子(unary functor,uf)。为了达到这个目的,它们需要两个参数:要转换的bf和一个值(v)。

bind1st和bind2nd允许为二元仿函数或判断式绑定一个值,从而将那个值固定下来。你可以绑定第一个或者第二个参数。随即,二元仿函数会变成一元仿函数。比如:

f = std::bind1st( functor, v); 'f( x)'等价于'functor( v, x)'
f = std::bind2nd( functor, v); 'f( x)'等价于'functor( x, v)'

先举两个例子看看bind1st和bind2nd的用法。
 

int a[] = {1, 2, 100, 200};
std::vector< int> arr(a, a + 4);

1. // 移除所有小于100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::bind2nd( std::less< int>(), 100)), arr.end()); 

这里的比较表达式相当于arr.value < 100

2. 如果用bind1st则表达的意思就恰恰相反
// 移除所有大于100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::bind1st( std::less< int>(), 100)), arr.end()); 
这里的表达式相当于100 < arr.value

3. 当然为了实现删除大于100的元素你同样可以使用bind2nd
// 移除所有大于100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::bind2nd( std::greater< int>(), 100)), arr.end()); 

4. 前面说道=的比较,比如说x <= k怎么实现呢,std又提供了一个好东西not1,我们可以说 !(x > k) 和 x <= k是等价的,那么我们看看下面的表达式:
// 移除所有小于等于100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::not1(std::bind2nd( std::greater< int>(), 100))), arr.end()); 
说明:not1是否定返回值是单目的函数,std中还有not2它是否定返回值是双目的函数



0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:356547次
    • 积分:4361
    • 等级:
    • 排名:第7159名
    • 原创:89篇
    • 转载:134篇
    • 译文:0篇
    • 评论:9条
    博客专栏
    最新评论