std::bind 详解及参数解析

简介:
// Bind_std_function.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <iostream>
#include <functional>
#include <random>
#include <memory>
//学习bind的用法
void f(int n1, int n2, int n3, const int & n4, int n5)
{
    std::cout << n1 << ' ' << n2 << ' ' << n3 << ' ' << n4 << ' ' << n5 << "\n";
}

int g(int n1)
{
    return n1 + 100;
}
struct Foo {
    Foo() = default;
    Foo(const Foo & a)
    {
        data = a.data;
        std::cout << "复制构造" << std::endl;
    }
    void print_sum(int n1, int n2)
    {
        std::cout << n1 + n2 << '\n';
    }
    int data = 10;
};

//////////////////////////////////////////////////////////////////////////
//std::bind的不同的placeholders个数证明调用函数体时需要传入的参数量及位置
//std::bind的时候目标的函数的参数的顺序与bind的时候的顺序的一一对应的
//////////////////////////////////////////////////////////////////////////

int _tmain(int argc, _TCHAR* argv[])
{
    int n = 7;
    auto f1 = std::bind(f, std::placeholders::_2, std::placeholders::_1, 43, std::cref(n), n);
    //第一位置 目标函数(f)的第一个参数 是调用时传的第二个参数
    //第二位置 目标函数(f)的第二个参数 是调用时传的第一个参数
    //第三位置 目标函数(f)的第三个参数 是43
    //第四位置 目标函数(f)的第四个参数 是n的按址传递
    //第五位置 目标函数(f)的第五个参数 是n
    n = 10;
    f1(1, 2);//相当于f(2,1,43,10,7);

    using namespace std::placeholders;
    auto f2 = std::bind(f, _3, std::bind(g, _3), _3, 4, 5);
    //第一位置 目标函数f的第一个参数 是调用时传的第三个参数
    //第二位置 目标函数f的第二个参数 是调用时传的g(第三个参数)
    //第三位置 目标函数f的第三个参数 是调用时传的第三个参数
    //第四位置 目标函数f的第四个参数 是4
    //第五位置 目标函数f的第五个参数 是5
    //由此可见,调用时的第一个参数和第二个参数是没有用的。调用时你把第一个或第二个参数传多少都是没有用的
    f2(1000, 2000, 55);//f(55,g(55),55,4,5);

    // common use case: binding a RNG with a distribution
    std::default_random_engine e;
    std::uniform_int_distribution<> d(0, 10);
    std::cout << d(e) << std::endl;//生成一个随机数

    std::function<int()> rnd = std::bind(d, e);//rnd就相当于d(e)
    for (int n = 0; n < 10; ++n)
        std::cout << rnd() << ' ';
    std::cout << '\n';


    //绑定类成员函数用对象的指针
    Foo foo;
    auto f3 = std::bind(&Foo::print_sum, &foo, 95, _1);
    f3(5);

    // 绑定类成员变量
    std::cout << "测试绑定类成员" << std::endl;
    auto f4 = std::bind(&Foo::data, _1);
    std::cout << f4(foo) << '\n';
    //std::cout << f4(&foo) << '\n';//尝试传入类对象指针编译不通过
    std::cout << f4(std::cref(foo)) << '\n';//引用包装传递

    //测试发现vs2013不支持Foo的智能指针做为f4的参数
    system("pause");
    return 0;
}
复制代码

 

相关文章
|
2月前
|
分布式计算 大数据 数据库连接
maxcompute开发环境问题之参数解析失败如何解决
MaxCompute开发环境是指设置和配置用于开发MaxCompute项目的本地或云端环境;本合集将指导用户如何搭建和管理MaxCompute开发环境,包括工具安装、配置和调试技巧。
|
25天前
|
机器学习/深度学习 算法 编译器
【C++ 泛型编程 中级篇】深度解析C++:类型模板参数与非类型模板参数
【C++ 泛型编程 中级篇】深度解析C++:类型模板参数与非类型模板参数
46 0
|
25天前
|
存储 安全 编译器
【C++ 17 新功能 std::visit 】深入解析 C++17 中的 std::visit:从原理到实践
【C++ 17 新功能 std::visit 】深入解析 C++17 中的 std::visit:从原理到实践
69 0
|
1月前
|
缓存 前端开发 Java
【二十八】springboot之通过threadLocal+参数解析器实现同session一样保存当前登录信息的功能
【二十八】springboot之通过threadLocal+参数解析器实现同session一样保存当前登录信息的功能
29 1
|
29天前
|
存储 前端开发 算法
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析(一)
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析
42 0
|
29天前
|
存储 并行计算 Java
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析(二)
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析
62 0
|
25天前
|
存储 安全 编译器
【C++ 17 泛型容器对比】C++ 深度解析:std::any 与 std::variant 的细微差别
【C++ 17 泛型容器对比】C++ 深度解析:std::any 与 std::variant 的细微差别
47 1
|
28天前
|
设计模式 算法 编译器
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景(三)
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景
26 0
|
28天前
|
设计模式 存储 程序员
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景(二)
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景
40 0
|
28天前
|
存储 设计模式 算法
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景(一)
【C++ 泛型编程 高级篇】 C++ 17 解析std::apply 的多种应用场景
49 0

推荐镜像

更多