#include <iostream>
#include <string>
#include <boost\bind.hpp> using namespace std;
using namespace boost; int func(int x, int y)
{
return x + y;
} struct struct_func
{
int func(int x, int y)
{
return x*y;
}
}; int main(int argc, char *argv[])
{
// 绑定普通函数
auto ref = boost::bind(func, 20, 10)();
cout << "绑定调用: " << ref << endl; // 绑定函数指针
typedef decltype(&func) f_type;
f_type ptr_a = func;
int x = 100, y = 200;
cout << "绑定调用: " << boost::bind(ptr_a, _1, _2)(x, y) << endl;
cout << "传入单参数: " << boost::bind(ptr_a, _1, 20)(10) << endl; // 绑定成员函数
struct_func ptr_b;
auto struct_ref = boost::bind(&struct_func::func, ptr_b, _1, _2)(10, 10);
cout << "绑定调用: " << struct_ref << endl; getchar();
}

function 参数绑定

#include <iostream>
#include <string>
#include <boost\function.hpp>
#include <boost\bind.hpp> using namespace std; float MyFunc(int x, int y)
{
return x + y;
} struct MyStruct
{
int add(int x, int y)
{
return x *y;
}
}; int main(int argc,char *argv[])
{
// function 指向普通函数
boost::function<float(int, int)> function_ptr; function_ptr = MyFunc; // 将MyFunc用ptr来存储
if (function_ptr)
{
cout << "调用指针: " << function_ptr(10, 20) << endl;
}
function_ptr = 0; // function 指向成员函数
boost::function<int(int, int)> struct_ptr;
MyStruct sc; struct_ptr = boost::bind(&MyStruct::add,&sc, _1, _2);
cout <<"调用指针: " << struct_ptr(10, 20) << endl;
getchar();
}

ref库的使用

#include <iostream>
#include <string>
#include <vector>
#include <boost\bind.hpp>
#include <boost\function.hpp> using namespace std; template<typename T>
struct summary
{
typedef void result_type;
T sum; summary(T v = T()) : sum(v){}
void operator()(T const &x)
{
sum += x;
}
}; int main(int argc, char *argv[])
{
vector<int> vect = { 1, 3, 5, 7, 9 };
summary<int> s; // 定义有状态函数对象 boost::function<void(int const&)> func(ref(s)); // function 包装引用 std::for_each(vect.begin(), vect.end(), func);
cout << "求和结果: " << s.sum << endl; getchar();
}

使用普通回调函数

#include <iostream>
#include <string>
#include <vector>
#include <boost\bind.hpp>
#include <boost\function.hpp> using namespace std; // 定义回调函数
void call_back_func(int x)
{
cout << "执行回调函数(数值翻倍): " << x * 2 << endl;
} class MyClass
{
private:
typedef boost::function<void(int)> func_ptr; // function 类型定义
func_ptr func;
int n; public:
// 定义构造函数
MyClass(int i) :n(i){} // 存储回调函数
template<typename CallBack>
void accept(CallBack call)
{
func = call;
}
// 运行函数
void run()
{
func(n);
}
}; int main(int argc, char *argv[])
{
MyClass ptr(10); ptr.accept(call_back_func); // 传入回调函数
ptr.run(); getchar();
}

带状态的回调函数,ref库传递引用

#include <iostream>
#include <string>
#include <vector>
#include <boost\bind.hpp>
#include <boost\function.hpp> using namespace std; class MyClass
{
private:
typedef boost::function<void(int)> func_ptr; // function 类型定义
func_ptr func;
int n; public:
// 定义构造函数
MyClass(int i) :n(i){} // 存储回调函数
template<typename CallBack>
void accept(CallBack call)
{
func = call;
}
// 运行函数
void run()
{
func(n);
}
}; class call_back_obj
{
private:
int x; public:
call_back_obj(int i) :x(i){}
void operator()(int i)
{
cout << "回调函数: " << i * x << endl;
}
}; int main(int argc, char *argv[])
{
MyClass ptr(10);
call_back_obj call_obj(2); ptr.accept(ref(call_obj)); ptr.run();
ptr.run(); getchar();
}

通过类绑定多个callback

#include <iostream>
#include <string>
#include <vector>
#include <boost\bind.hpp>
#include <boost\function.hpp> using namespace std; class MyClass
{
private:
typedef boost::function<void(int)> func_ptr; // function 类型定义
func_ptr func;
int n; public:
// 定义构造函数
MyClass(int i) :n(i){} // 存储回调函数
template<typename CallBack>
void accept(CallBack call)
{
func = call;
}
// 运行函数
void run()
{
func(n);
}
}; class call_back_factory
{
public:
void call_back_func_a(int x)
{
cout << "回调函数1: " << x * 2 << endl;
} void call_back_func_b(int x, int y)
{
cout << "回调函数2: " << x * y << endl;
}
}; int main(int argc, char *argv[])
{
MyClass ptr(10);
call_back_factory factory; ptr.accept(bind(&call_back_factory::call_back_func_a, factory, _1));
ptr.run(); ptr.accept(bind(&call_back_factory::call_back_func_b, factory, _1, 200));
ptr.run();
getchar();
}

信号与槽 一个信号关联多个槽,信号发出后,槽函数相应。

#include <iostream>
#include <string>
#include <boost\signals2.hpp> using namespace std; void slots_a()
{
cout << "slots_a called" << endl;
} void slots_b()
{
cout << "slots_b called" << endl;
} int main(int argc, char *argv[])
{ // 简单的链接
boost::signals2::signal<void()> sig; // 定义信号对象 sig.connect(&slots_a);
sig.connect(&slots_b); sig(); // 发射信号 getchar();
}

信号的返回值

#include <iostream>
#include <string>
#include <boost\signals2.hpp> using namespace std; template<int T,int C>
struct slots
{
int operator()(int x)
{
return x + T + C;
}
}; int main(int argc, char *argv[])
{ boost::signals2::signal<int(int)> sig; // 0 代表组
sig.connect(0,slots<10,20>()); int ref = *sig(5);
cout << "获取返回值: " << ref << endl; getchar();
}

合并器的使用

#include <iostream>
#include <string>
#include <numeric>
#include <boost\signals2.hpp> using namespace std; template<int T, int C>
struct slots
{
int operator()(int x)
{
return x + T + C;
}
}; template<typename T>
class combiner
{
T v; public:
typedef std::pair<T, T> result_type;
combiner(T t = T()) : v(t){} // 构造函数 template<typename InputIterator>
result_type operator()(InputIterator begin, InputIterator end) const
{
// 为空则返回0
if (begin == end)
return result_type(); vector<T> vec(begin, end); // 容器保存插槽调用结果 T sum = std::accumulate(vec.begin(), vec.end(), v);
T max = *std::max_element(vec.begin(), vec.end()); return result_type(sum, max);
}
}; int main(int argc, char *argv[])
{
boost::signals2::signal<int(int), combiner<int>> sig; sig.connect(0, slots<10, 20>()); auto x = sig(2);
cout << x.first << x.second << endl;;
getchar();
}

C++ Boost 函数与回调应用的更多相关文章

  1. boost 函数与回调

    result_of 含义:result_of可以帮助程序员确定一个调用表达式的返回类型,主要用于泛型编程和其他boost库组件,它已经被纳入TR1 头文件:<boost/utility/resu ...

  2. php变量函数,回调函数

    一,变量可以直接传递函数 <?php function demo($num , $n )//$n是个函数 { for($i=0;$i<$num;++$i) { if($n($i)) { e ...

  3. paip.函数方法回调机制跟java php python c++的实现

    paip.函数方法回调机制跟java php python c++的实现 作者Attilax 艾龙,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http:// ...

  4. C++中类成员函数作为回调函数

    注:与tr1::function对象结合使用,能获得更好的效果,详情见http://blog.csdn.net/this_capslock/article/details/38564719 回调函数是 ...

  5. Go基础系列:函数(2)——回调函数和闭包

    回调函数和闭包 当函数具备以下两种特性的时候,就可以称之为高阶函数(high order functions): 函数可以作为另一个函数的参数(典型用法是回调函数) 函数可以返回另一个函数,即让另一个 ...

  6. 精读JavaScript模式(五),函数的回调、闭包与重写模式

    一.前言 今天地铁上,看到很多拖着行李箱的路人,想回家了. 在上篇博客结尾,记录到了函数的几种创建方式,简单说了下创建差异,以及不同浏览器对于name属性的支持,这篇博客将从第四章函数的回调模式说起. ...

  7. C++中 线程函数为静态函数 及 类成员函数作为回调函数

    线程函数为静态函数: 线程控制函数和是不是静态函数没关系,静态函数是在构造中分配的地址空间,只有在析构时才释放也就是全局的东西,不管线程是否运行,静态函数的地址是不变的,并不在线程堆栈中static只 ...

  8. Javascript中的回调函数和匿名函数的回调

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. Node.js学习笔记(3)——关于回调函数和函数的回调

    说明:本人是node.js的初学者,尝试向别人解释这是怎么回事是自我学习的一个好方法.如果你发现有些地方并不是那么正确,欢迎提出来让我知道以便修正,共同进步,谢过^_^.       欢迎交流,本人微 ...

  10. Javascript中的回调函数和匿名函数的回调示例介绍

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

随机推荐

  1. 非VIP用户下载限速,原来是这么实现的

    在日常工作之余,二狗子其实还是个隐藏的大触,一手素描画得出神入化,不少看过的小伙伴嗷嗷叫着求分享.为了让更多小粉丝能看到自己的作品,二狗子开发了一个提供有版权的素描稿件的下载网站. 二狗子的小网站,只 ...

  2. 题解| CF1561D2. Up the Strip(递推)

    题目链接:Here 这个思路学习自 Harris-H ,考虑递推而不是DP 与 D1 不同,开始考虑 \(f_{i-1} \to f_i\) 显然操作 1 多了 \(f_{i-1}\) ,操作2 多了 ...

  3. 拥抱开放,Serverless 时代的下一征程

    Serverless 作为云计算的最佳实践和未来演进趋势,其全托管免运维的使用体验和按量付费的成本优势使得它在云原生时代备受推崇.Serverless 的使用场景也由事件驱动,数据处理等部分特定场景转 ...

  4. Web3初步实践总结

    大家好~Web3是2021年才开始的浪潮,我非常赞同Web3的去中心化的理念,并且最近从Web2全面转向Web3了. 现在与大家分享我的实践的经验,希望对大家有所帮助,谢谢! 目录 为什么要转向Web ...

  5. java进阶(5)--package与import

    一.package 1.package的作用:为了方便程序的管理 2.package怎么使用:package+包名,只能出现在java代码的第一行 3.package命令规范:一般采用公司域名倒序方式 ...

  6. kafka Linux环境搭建安装及命令创建队列生产消费消息

    本文为博主原创,未经允许不得转载: 1. 安装JDK 由于Kafka是用Scala语言开发的,运行在JVM上,因此在安装Kafka之前需要先安装JDK. yum install java‐1.8.0‐ ...

  7. [转帖]PostgreSQL数据库的版本历史及关键变化

    https://cloud.tencent.com/developer/article/2311843 举报 PostgreSQL是一个强大的开源关系型数据库,它的发展历程充满了创新和卓越的设计.让我 ...

  8. [转帖]nginx中的if和else语法

    https://www.dyxmq.cn/it/nginx/nginx-if.html nginx支持if语法,语法和平常的代码格式差不多:   1 2 3 if ($xxx = xxx) {     ...

  9. [转帖]linux下查看内存频率,内核函数,cpu频率

    https://www.cnblogs.com/lovesKey/p/10900501.html 查看CPU: cat /proc/cpuinfo # 总核数 = 物理CPU个数 X 每颗物理CPU的 ...

  10. [转帖]redis缓存命中率介绍

    缓存命中率的介绍 命中:可以直接通过缓存获取到需要的数据. 不命中:无法直接通过缓存获取到想要的数据,需要再次查询数据库或者执行其它的操作.原因可能是由于缓存中根本不存在,或者缓存已经过期. 通常来讲 ...