fix #38: rephrase function pointer

This commit is contained in:
Changkun Ou
2018-10-01 12:32:25 +02:00
parent 5960578f7f
commit 6411c5cec3

View File

@@ -118,27 +118,27 @@ add(1.1, 2.2);
### std::function
Lambda 表达式的本质是一个函数对象,当 Lambda 表达式的捕获列表为空时Lambda 表达式还能够作为一个函数指针进行传递,例如:
Lambda 表达式的本质是一个函数对象,当 Lambda 表达式的捕获列表为空时Lambda 表达式还能够作为一个函数类型进行传递,例如:
```cpp
#include <iostream>
using foo = void(int); // 定义函数指针, using 的使用见上一节中的别名语法
using foo = void(int); // 定义函数类型, using 的使用见上一节中的别名语法
void functional(foo f) {
f(1);
f(1); // 编译器将其隐式转化成函数指针
}
int main() {
auto f = [](int value) {
std::cout << value << std::endl;
};
functional(f); // 函数指针调用
functional(f); // 作为函数类型传递
f(1); // lambda 表达式调用
return 0;
}
```
上面的代码给出了两种不同的调用形式,一种是将 Lambda 作为函数指针传递进行调用,而另一种则是直接调用 Lambda 表达式,在 C++11 中,统一了这些概念,将能够被调用的对象的类型,统一称之为可调用类型。而这种类型,便是通过 `std::function` 引入的。
上面的代码给出了两种不同的调用形式,一种是将 Lambda 作为函数类型传递进行调用,而另一种则是直接调用 Lambda 表达式,在 C++11 中,统一了这些概念,将能够被调用的对象的类型,统一称之为可调用类型。而这种类型,便是通过 `std::function` 引入的。
C++11 `std::function` 是一种通用、多态的函数封装,它的实例可以对任何可以调用的目标实体进行存储、复制和调用操作,它也是对 C++中现有的可调用实体的一种类型安全的包裹(相对来说,函数指针的调用不是类型安全的),换句话说,就是函数的容器。当我们有了函数的容器之后便能够更加方便的将函数、函数指针作为对象进行处理。例如: