使用C++11 std::bind和std::function实现回调机制

简介:

#include <functional>
#include <iostream>


#define  MY_CALLBACK_0(__selector__,__target__,  ) std::bind(&__selector__,__target__, ##__VA_ARGS__)
#define  MY_CALLBACK_1(__selector__,__target__,  ) std::bind(&__selector__,__target__, std::placeholders::_1, ##__VA_ARGS__)
#define  MY_CALLBACK_2(__selector__,__target__,  ) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, ##__VA_ARGS__)
#define  MY_CALLBACK_3(__selector__,__target__,  ) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3, ##__VA_ARGS__)


typedef std::function< void ()> CALLBACK_FUNC;

class  Sender
{
public :
    Sender() { callback = nullptr; }
     virtual  ~Sender() {}

public :
     void  emit()
    {
        std::cout << "I am A,I send a message." << std::endl;
         if  (callback) callback();
    }

     void  setTarget(CALLBACK_FUNC target)
    {
        callback = target;
    }

public :
    CALLBACK_FUNC callback;
};

struct  foo
{
     void  doSomething_MemberFunction()  const
    {
        std::cout << "I am member function,I got a message!" << std::endl;
    }

     static   void  doSomething_StaticMemberFunction( int  i)
    {
        std::cout << "I am static member function,I got a message! i=" << i << std::endl;
    }
};

void  doSomething_GlobalFunction()
{
    std::cout << "I am global function,I got a message!" << std::endl;
}

class  Functor
{
public :
     void   operator ()()
    {
        std::cout << "I am a functor!" << std::endl;
    }
};

void  testBindFunction()
{
    Sender sender;
    foo f;

     //  成员函数
    sender.setTarget(std::bind(&foo::doSomething_MemberFunction, &f));
     // sender.setTarget(MY_CALLBACK_0(foo::doSomething_MemberFunction, &f));
    sender.emit();

     //  全局函数
    sender.setTarget(doSomething_GlobalFunction);
    sender.emit();

     //  静态成员函数
    sender.setTarget(std::bind(foo::doSomething_StaticMemberFunction, 666));
    sender.emit();

     //  Lambda表达式
    auto lambda = []() { std::cout << "I am Lambda!" << std::endl; };
    sender.setTarget(lambda);
    sender.emit();

     //  仿函数
    sender.setTarget(Functor());
    sender.emit();
}
目录
相关文章
|
29天前
|
安全 算法 程序员
【C/C++ 文件操作】深入理解C语言中的文件锁定机制
【C/C++ 文件操作】深入理解C语言中的文件锁定机制
32 0
|
30天前
|
存储 安全 编译器
【C++ 17 新功能 std::visit 】深入解析 C++17 中的 std::visit:从原理到实践
【C++ 17 新功能 std::visit 】深入解析 C++17 中的 std::visit:从原理到实践
70 0
|
17天前
|
编译器 C语言 C++
【C++的奇迹之旅(二)】C++关键字&&命名空间使用的三种方式&&C++输入&输出&&命名空间std的使用惯例
【C++的奇迹之旅(二)】C++关键字&&命名空间使用的三种方式&&C++输入&输出&&命名空间std的使用惯例
|
28天前
|
安全 程序员 C++
【C++ 基本知识】现代C++内存管理:探究std::make_系列函数的力量
【C++ 基本知识】现代C++内存管理:探究std::make_系列函数的力量
101 0
|
29天前
|
存储 编译器 C++
从Proto到C++:探索Protocol Buffers的强大转换机制
从Proto到C++:探索Protocol Buffers的强大转换机制
245 4
|
30天前
|
存储 安全 编译器
【C++ 函数设计的艺术】深挖 C++ 函数参数的选择 智能指针与 std::optional:最佳实践与陷阱
【C++ 函数设计的艺术】深挖 C++ 函数参数的选择 智能指针与 std::optional:最佳实践与陷阱
108 0
|
30天前
|
存储 安全 编译器
【C++ 17 泛型容器对比】C++ 深度解析:std::any 与 std::variant 的细微差别
【C++ 17 泛型容器对比】C++ 深度解析:std::any 与 std::variant 的细微差别
50 1
|
30天前
|
算法 编译器 C++
【C++ 泛型编程 中级篇】C++ 编译时技术:探索 if constexpr 和 std::enable_if
【C++ 泛型编程 中级篇】C++ 编译时技术:探索 if constexpr 和 std::enable_if
40 0
|
1天前
|
设计模式 Java C++
【C++高阶(八)】单例模式&特殊类的设计
【C++高阶(八)】单例模式&特殊类的设计
|
1天前
|
编译器 C++
【C++基础(八)】类和对象(下)--初始化列表,友元,匿名对象
【C++基础(八)】类和对象(下)--初始化列表,友元,匿名对象