前面讲了Lambda表达式,预期进门相关的就是函数对象包装器,本篇将会介绍函数对象包装器
C++新特性13_函数对象包装器function与bind机制
1. 函数对象包装器function:类似c#中的function委托
为了函数提供了一种容器(封装),存放在对象或者变量中。通俗一些的理解就是把函数当做对象来处理。
C++11 std::function
是一种通用、多态的函数封装,它的实例可以对任何可以调用的目标实体进行存储、复制和调用操作,它也是对 C++中现有的可调用实体的一种类型安全的包裹(相对来说,函数指针的调用不是类型安全的),换句话说,就是函数的容器。当我们有了函数的容器之后便能够更加方便的将函数、函数指针作为对象进行处理。
函数对象包装器支持4种函数的封装:
- 普通函数
- 匿名函数/Lambda表达式
- 类成员函数
- 仿函数(重载了()运算符的函数)
1.1 普通函数的封装
#include <iostream>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std;
int test(int n) {
cout << n << endl;
return n;
}
//应用举例
int main()
{
//函数对象包装器:
//为了函数提供了一种容器(封装),存放在对象或者变量中
test(1);
//<int >返回值;(int)参数列表;
function<int(int)>f = test;
f(123);
return 0;
}
1.2 普通函数之外函数的封装
- 匿名函数的封装
- 类成员函数的封装
- 仿函数(重载了()运算符的函数)的封装
#include <iostream>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std;
int test(int n) {
cout << n << endl;
return n;
}
class CTest {
public:
CTest() {}
int MyTest(int n) {
cout << n << endl;
return n;
}
//仿函数
int operator()(int n) {
cout << n << endl;
return n;
}
};
//应用举例
int main()
{
//函数对象包装器:
//为了函数提供了一种容器(封装),存放在对象或者变量中
test(1);
//普通函数的封装
//<int >返回值;(int)参数列表;
function<int(int)>f = test;
//f(123);
//匿名函数
function<int(int)>f2 = [](int n)->int {
cout << n << endl;
return n;
};
f2(123);
//类的成员函数会传递一个this指针 CTest*指this指针
function<int(CTest*,int)>f3 = &CTest::MyTest;
CTest t;
f3(&t,123);
//仿函数的调用,t是对象,类似于函数的使用
t(123);
function<int(CTest*, int)>f4 = &CTest::operator();
f4(&t,123);
return 0;
}
2. bind机制:std::bind/std::placeholder
参数不想按顺序进行传递,类似默认参数,但可以打破顺序。
而 std::bind
则是用来绑定函数调用的参数的,它解决的需求是我们有时候可能并不一定能够一次性获得调用某个函数的全部参数,通过这个函数,我们可以将部分调用参数提前绑定到函数身上成为一个新的对象,然后在参数齐全后,完成调用。
#include <iostream>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std;
//参数比较多
void add(int a,int b,int c) {
cout << a << b << c << endl;
}
int main()
{
//bind机制:参数不想按顺序进行传递,类似默认参数,但可以打破顺序
//函数与参数绑定在一起,变成新的对象
auto a=bind(add,1,2,3);
a(); //输出123
//第二个参数在实际的运行再给值,placeholders::_1 占位符,_1表示第一个参数
auto foo2 = bind(add, 1, placeholders::_1, 3);
foo2(3); //输出133
//第二个参数在实际的运行再给值,placeholders::_1 占位符,_1表示第一个参数 _1表示第二个参数
auto foo3 = bind(add, placeholders::_2, placeholders::_1, 3);
//1对应placeholders::_1,2对应placeholders::_2
foo3(1,2); //输出213
return 0;
}
3. 视频学习地址:函数对象包装器function与bind机制
4. 学习笔记:函数对象包装器function与bind机制笔记