常规函数适配器,成员函数适配器

stl算法中,可以使用函数指针以及仿函数传递算法.

那么为什么还需要常规函数适配器呢?

因为,常规函数适配器无"配接能力"

例子:

/* 
 * File:   main.cpp
 * Author: Vicky.H
 * Email:  eclipser@163.com
 */
#include <iostream>
#include <vector>
#include <algorithm>
#include <functional>

class A {
public:
    int id;

    A() { }

    A(int id) : id(id) { }
};

// 普通函数,需要2个参数!但,for_each,find_if等stl算法,只提供1个参数,第2个参数需要std::bind2nd提供

bool id_eq(const A* a, const int& id) {
    return a->id == id;
}

/*
 * 
 */
int main(void) {
    A* aa[] = {new A(1), new A(2), new A(3), new A(4), new A(5)};
    std::vector<A*> av(aa, aa + 5);

    const int id = 5;
    // 我们需要查询id为5的A
    // std::find_if(av.begin(), av.end(), id_eq);    // 注意,我们没办法为id_eq传递第2个参数为5,顾会出现  error: too few arguments to function,这也需要普通函数适配器的原因

    // std::ptr_fun(id_eq);
    // std::bind2nd(std::ptr_fun(id_eq), id);
    std::vector<A*>::iterator it = std::find_if(av.begin(), av.end(), std::bind2nd(std::ptr_fun(id_eq), id));
    std::cout << (*it)->id << std::endl;
    
    // 销毁指针...
    for (int i = 0; i < av.size(); i++) delete av[i];

    return 0;
}

 

5
 

 

成员函数适配器:

/* 
 * File:   main.cpp
 * Author: Vicky.H
 * Email:  eclipser@163.com
 */
#include <iostream>
#include <algorithm>
#include <functional>
#include <vector>

class A{public:virtual void display() = 0;};
class B : public A{public:virtual void display() {std::cout << "B" << std::endl;} virtual ~B(){}};
class C : public A{public:void display() {std::cout << "C" << std::endl;}};
class D : public B{public:void display() {std::cout << "D" << std::endl;}};


/*
 * 
 */
int main(void) {

    std::vector<A*> pAV;
    
    pAV.push_back(new B);
    pAV.push_back(new C);
    pAV.push_back(new D);
    pAV.push_back(new B);
    
    for (int i = 0; i < pAV.size(); i++) {
        pAV[i]->display();
    }

    std::cout << "---------------------------" << std::endl;
    
    /**为什么不能同全局函数一样直接传递函数名而成员函数必须以  &类名::函数名  的方式,因为需要考虑static成员函数的情况!*/
    std::for_each(pAV.begin(),pAV.end(), std::mem_fun(&A::display) /* std::mem_fun_ref(&A::display)由于我们创建的指针,这里不能使用处理对象的成员函数适配器*/);

    return 0;
}


B
C
D
B
---------------------------
B
C
D
B

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、概述 函数适配器是一种可以改变函数行为的工具。在STL中,函数适配器通常用来将一个函数的参数或返回值类型改变为另一种类型,或者将一个函数的参数或返回值进行逻辑转换。 二、函数适配器的种类 1. bind1st和bind2nd bind1st和bind2nd是两个函数适配器,它们用来将一个二元函数转换为一个一元函数。bind1st将第一个参数绑定为指定值,而bind2nd将第二个参数绑定为指定值。 例如,在STL中,有一个二元函数less,用于比较两个值的大小。我们可以使用bind1st将其转换为一个只比较一个值和指定值的一元函数: ```c++ #include <functional> #include <iostream> using namespace std; int main() { int a = 5; less<int> l; cout << l(3, a) << endl; // true bind1st(l, a)(3); // false return 0; } ``` 2. not1和not2 not1和not2也是两个函数适配器,它们用来将一个一元函数或二元函数的返回值取反。 例如,在STL中,有一个一元函数not1,用于将一个bool值取反。我们可以使用not1将一个返回bool值的一元函数的返回值取反: ```c++ #include <functional> #include <iostream> using namespace std; int main() { bool b = true; not1<less<int> > n; cout << n(3, 5) << endl; // false not1<logical_and<bool> > n2; cout << n2(true, false) << endl; // true return 0; } ``` 3. negate negate是一个函数适配器,它用来将一个一元函数的返回值取负。 例如,在STL中,有一个一元函数negate,用于将一个数值取负。我们可以使用negate将一个返回数值的一元函数的返回值取负: ```c++ #include <functional> #include <iostream> using namespace std; int main() { int a = 5; negate<int> n; cout << n(a) << endl; // -5 return 0; } ``` 4. plus、minus、multiplies、divides、modulus plus、minus、multiplies、divides、modulus是五个函数适配器,它们用于将两个数值进行加、减、乘、除、取余运算。 例如,在STL中,有一个二元函数plus,用于将两个数值相加。我们可以使用plus将两个返回数值的一元函数的返回值相加: ```c++ #include <functional> #include <iostream> using namespace std; int main() { int a = 5; plus<int> p; cout << p(a, 3) << endl; // 8 return 0; } ``` 5. compose1 compose1是一个函数适配器,它用于将一个一元函数f和一个一元函数g组合成一个新的一元函数f(g(x))。 例如,在STL中,有一个一元函数negate,用于将一个数值取负,和一个一元函数abs,用于将一个数值取绝对值。我们可以使用compose1将这两个一元函数组合成一个新的一元函数abs(negate(x)): ```c++ #include <functional> #include <iostream> using namespace std; int main() { int a = -5; compose1(negate<int>(), abs<int>())(a); // 5 return 0; } ``` 6. compose2 compose2是一个函数适配器,它用于将一个二元函数f和两个一元函数g1、g2组合成一个新的二元函数f(g1(x), g2(y))。 例如,在STL中,有一个二元函数plus,用于将两个数值相加,和两个一元函数negate和abs。我们可以使用compose2将这三个函数组合成一个新的二元函数abs(negate(x)) + abs(negate(y)): ```c++ #include <functional> #include <iostream> using namespace std; int main() { int a = -5, b = -3; compose2(plus<int>(), compose1(negate<int>(), abs<int>()), compose1(negate<int>(), abs<int>()))(a, b); // 8 return 0; } ``` 三、小结 函数适配器是一种强大的工具,可以改变函数的行为,使得我们可以更加灵活地使用STL中的函数。在实际应用中,我们可以根据具体的需求选择合适的函数适配器来实现所需的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值