C++11/14学习(九)函数对象包装器

std::function

Lambda 表达式的本质是一个函数对象。
当 Lambda 表达式的捕获列表为空时,Lambda 表达式还能够作为一个函数指针进行传递,例如:

#include <iostream>
using foo = void(int); // 定义函数指针, using 的使用见上一节中的别名语法
void functional(foo f) {
    f(1);
}
int main() {
    auto f = [](int value) {
        std::cout << value << std::endl;
    };
    functional(f); // 函数指针调用
    f(1); // lambda 表达式调用
    return 0;
}

上面的代码给出了两种不同的调用形式:

  1. 将 Lambda 作为函数指针传递进行调用
  2. 直接调用 Lambda 表达式

在 C++11 中统一了这些概念,将能够被调用的对象的类型,统一称之为可调用类型,而这种类型,便是通过std::function 引入的。

C++11 std::function 是一种通用、多态的函数封装,可以对任何可调用目标实体进行存储、复制和调用操作。
它也是对 C++中现有的可调用实体的一种类型安全的包裹(相对来说,函数指针的调用不是类型安全的),换句话说,就是函数的容器。
当我们有了函数的容器之后便能够更加方便的将函数、函数指针作为对象进行处理。
例如:

#include <functional>
#include <iostream>
int foo(int para) {
    return para;
}
int main() {
    // std::function 包装了一个返回值为 int, 参数为 int 的函数
    std::function<int(int)> func = foo;
    int important = 10;
    std::function<int(int)> func2 = [&](int value) -> int {
        return 1 + value + important;
    };
    std::cout << func(10) << std::endl;
    std::cout << func2(10) << std::endl;
}

 

std::bind/std::placeholder

std::bind 是用来绑定函数调用参数的,它解决的需求是:
我们有时候可能并不一定能够一次性获得调用某个函数的全部参数。
通过这个函数,我们可以将部分调用参数提前绑定到函数身上成为一个新的对象,然后在参数齐全后,完成调用。
例如:

int foo(int a, int b, int c) {
    ;
}
int main() {
    // 将参数1,2绑定到函数 foo 上,
    // 但是使用 std::placeholders::_1 来对第一个参数进行占位
    auto bindFoo = std::bind(foo, std::placeholders::_1, 1, 2);
    // 这时调用 bindFoo 时,只需要提供第一个参数即可
    bindFoo(1);
}

posted on 2018-01-23 00:00 FerrisYu 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/ferrisyu/p/8331772.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值