bind1st和bind2nd这两个函数的用法

bind1st和bind2nd这两个函数的用法
http://yellowhong.bokee.com/viewdiary.15136014.html

以前在使用stl的过程中发现bind1st和bind2nd这两个函数,当时不太理解什么意思,今天在网上查了一下相关资料发现竟然很 简单,下面我就具体解释一下他们的用法。

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

 

         可能这么解释以后大家还不是很清楚,那么就说点白话吧。我们在做比较的时候所写的表达式像 x > k ,x < k,这里的k是一个参数表示你程序里面的表达式要和k值去比较。上面这两个表达式对应的应该是bind2nd ,简单的理解就是把k作为比较表达式的第二个参数。如果使用bind1st则对应的表达式是 k > x,k < x,也就是把k作为比较表达式的第一个参数。大家可能会注意到这里面没有=的比较,先别着急,后面将会说道如何实现=的比较。先举两个例子看看bind1st和bind2nd的用法。

int a[] = {1, 2, 100, 200};

std::vector< int> arr(a, a + 4);

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

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

如果用bind1st则表达的意思就恰恰相反

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

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

当然为了实现删除大于100的元素你同样可以使用bind2nd

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

前面说道=的比较,比如说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它是否定返回值是双目的函数

例子需要包含头文件

#include <vector>

#include <algorithm>

#include <functional>
http://yellowhong.bokee.com/viewdiary.15136014.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
函数适配器是一种特殊的函数对象,用于在函数调用中修改参数的顺序或值。`bind1st`和`bind2nd`是函数适配器的例子。 `bind1st`用于将一个二元函数(接受两个参数的函数)的第一个参数固定为一个特定的值。它接受一个二元函数和一个值作为参数,并返回一个新的函数对象,该对象将第一个参数绑定为给定值。这样,当调用新的函数对象时,它只需要一个参数,而不是两个。 例如,假设有一个二元函数`add`,它接受两个整数并返回它们的和。如果我们使用`bind1st`将第一个参数绑定为5,我们可以创建一个新的函数对象`add5`,它只需要一个参数,并将其与5相加。 ```cpp int add(int a, int b) { return a + b; } // 使用bind1st将第一个参数绑定为5 auto add5 = std::bind1st(add, 5); int result = add5(3); // 调用add5,相当于调用add(5, 3) // result 等于 8 ``` `bind2nd`与`bind1st`类似,但它将第二个参数固定为给定值。这样,新的函数对象在调用时只需要一个参数,并将其与给定值作为第二个参数传递给原始函数。 ```cpp int subtract(int a, int b) { return a - b; } // 使用bind2nd将第二个参数绑定为3 auto subtract3 = std::bind2nd(subtract, 3); int result = subtract3(7); // 调用subtract3,相当于调用subtract(7, 3) // result 等于 4 ``` 这些函数适配器可以方便地修改函数的参数顺序或固定某些参数的值,使其更适应特定的使用场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值