• C++11: std::function<void()> func;


    std::function介绍

    类模版std::function是一种通用、多态的函数封装。std::function的实例可以对任何可以调用的目标实体进行存储、复制、和调用操作,这些目标实体包括普通函数、Lambda表达式、函数指针、以及其它函数对象等。std::function对象是对C++中现有的可调用实体的一种类型安全的包裹(我们知道像函数指针这类可调用实体,是类型不安全的)。

    通常std::function是一个函数对象类,它包装其它任意的函数对象,被包装的函数对象具有类型为T1, …,TN的N个参数,并且返回一个可转换到R类型的值。std::function使用 模板转换构造函数接收被包装的函数对象;特别是,闭包类型可以隐式地转换为std::function

    最简单的理解就是:

       通过std::function对C++中各种可调用实体(普通函数、Lambda表达式、函数指针、以及其它函数对象等)的封装,形成一个新的可调用的std::function对象;让我们不再纠结那么多的可调用实体。一切变的简单粗暴。 

    #include <functional>
    #include <iostream>
    using namespace std;
     
    std::function< int(int)> Functional;
     
    // 普通函数
    int TestFunc(int a)
    {
        return a;
    }
     
    // Lambda表达式
    auto lambda = [](int a)->int{ return a; };
     
    // 仿函数(functor)
    class Functor
    {
    public:
        int operator()(int a)
        {
            return a;
        }
    };
     
    // 1.类成员函数
    // 2.类静态函数
    class TestClass
    {
    public:
        int ClassMember(int a) { return a; }
        static int StaticMember(int a) { return a; }
    };
     
    int main()
    {
        // 普通函数
        Functional = TestFunc;
        int result = Functional(10);
        cout << "普通函数:"<< result << endl;
     
        // Lambda表达式
        Functional = lambda;
        result = Functional(20);
        cout << "Lambda表达式:"<< result << endl;
     
        // 仿函数
        Functor testFunctor;
        Functional = testFunctor;
        result = Functional(30);
        cout << "仿函数:"<< result << endl;
     
        // 类成员函数
        TestClass testObj;
        Functional = std::bind(&TestClass::ClassMember, testObj, std::placeholders::_1);
        result = Functional(40);
        cout << "类成员函数:"<< result << endl;
     
        // 类静态函数
        Functional = TestClass::StaticMember;
        result = Functional(50);
        cout << "类静态函数:"<< result << endl;
     
        return 0;
    }

    std::function 最大的用处是函数回调;

  • 相关阅读:
    watch 监听路由的改变
    三元运算符
    element-ui动态更改el-table某个单元格字体颜色
    vue 跨域问题导致前端无法携带cookie
    Vue 用checkbox实现两两组合多选且禁用第三个。
    表格数据宽度自适应方案
    echarts细节问题
    es6 解构赋值
    学习笔记-Python基础15-持久化-文件、pickle、shelve
    学习笔记-Python基础14-PyCharm调试
  • 原文地址:https://www.cnblogs.com/yinwei-space/p/12708871.html
Copyright © 2020-2023  润新知