c++ bind 函数讲解

article/2025/10/19 6:34:46

1.bind 函数的使用详解

可以将bind函数看作一个通用的函数适配器,它接受一个可调用对象,生成一个新的可调用对象来“适应”原对象的参数列表。

调用bind的一般形式:auto newCallable = bind(callable,arg_list);`

其中,newCallable本身是一个可调用对象,arg_list是一个逗号分隔的参数列表,对应给定的callable的参数。即,当我们调用newCallable时,newCallable会调用callable,并传给它arg_list中的参数。

arg_list中的参数可能包含形如_n的名字,其中n是一个整数,这些参数是“占位符”,表示newCallable的参数,它们占据了传递给newCallable的参数的“位置”。数值n表示生成的可调用对象中参数的位置:_1为newCallable的第一个参数,_2为第二个参数,以此类推。

绑定成员函数

#include<iostream>

#include<functional>

using namespace std;

class Plus

{

   public:

    int plus(int a,int b)

    {

        return a+b;

    }

};

int main()

{

   Plus p;

   // 指针形式调用成员函数

   function<int(int,int)> func1 = std::bind(&Plus::plus,&p, placeholders::_1, placeholders::_2);

  // 对象形式调用成员函数

   function<int(int,int)> func2 = std::bind(&Plus::plus,p, placeholders::_1, placeholders::_2);

   cout<<func1(1,2)<<endl; //3

   cout<<func2(1,2)<<endl; //3

   return 0;

}

对应输出:

#include<iostream>

#include<functional>

using namespace std;

class Plus

{

   public:

    int plus(int a,int b)

    {

        cout<< __func__ << " " << a << " " << b << endl;

        return a+b;

    }

       static int plusEx(int a, int b)  //静态成员函数

       {

            cout<< __func__ << " " << a << " " << b << endl;

            return  a + b;

       }

};

//bind 可以将既有函数的参数绑定起来,从生成一个函数对象

void function1 (int d)

{

    cout << __func__ << " " << d << endl;

}

//如果有多个参数可以只绑定部分

void function2(int d1, int d2)

{

    cout<< __func__ << " " << d1 << " " << d2 << endl;

}

void fun(int& d1, int& d2, int& d3)

{

    d1 = 1;

    d2 = 2;

    d3 = 3;

    cout << __func__ << " " << d1 << " " << d2 << " "<< d3 <<endl;

}

int main()

{

   Plus p;

   // 指针形式调用成员函数

   function<int(int,int)> func1 = std::bind(&Plus::plus, &p, placeholders::_1, placeholders::_2);

  // 对象形式调用成员函数

   function<int(int,int)> func2 = std::bind(&Plus::plus, p, placeholders::_1, placeholders::_2);

   cout<<func1(1,2)<<endl; //3

   cout<<func2(1,2)<<endl; //3

   //静态成员函数

   function<int (int, int)> func3 = std::bind(&Plus::plusEx, placeholders::_1, placeholders::_2);

   cout<<func3(4,5)<<endl; //9

   

   auto f = bind(function1,6);  //绑定函数function1 的参数

   f();

  auto ff = bind(function2, placeholders::_1,9);  //绑定函数function1 的参数

  ff(10);

  int m1 = 4, m2 = 5, m3 = 6;

  auto fs = bind (fun, placeholders::_1, m2, ref(m3));

  fs(m1);

  //1.m1是通过placeholders绑定,是传引用绑定,因此在fun内的赋值会影响到m1

  //2.m2是通过参数绑定,是传值绑定,在fun内的赋值不会影响到m2

  //3.m3是通过ref的传引用绑定,因此在fun内的赋值会影响到m3

  cout << __func__ << " " << m1 << " " << m2 << " " << m3 << endl;

  return 0;

}

 


http://chatgpt.dhexx.cn/article/YmAwkFxY.shtml

相关文章

Bind函数详解

自己开发了一个股票软件&#xff0c;功能很强大&#xff0c;需要的点击下面的链接获取&#xff1a; QStockView股票智能分析报警软件下载链接 - 一字千金 - 博客园 Bind函数详解 目录 1 简介... 1 2 使用实例... 1 2.1 bind函数常规使用... 1 2.2 …

网络编程之bind函数

基本TCP客户端/服务器程序的套接字函数 1、bind函数把一个本地协议地址赋予一个套接字。对于网际协议&#xff0c;协议地址是32位的IPv4地址或是128位的IPv6地址与16位的TCP或UDP端口号的组合。 #include<sys/socket.h> int bind(int sockfd, const struct sockaddr, …

一阶数字低通滤波器设计matlab

一阶数字低通滤波器传递函数为&#xff1a; ωc2πfc ωc​为滤波截止角频率 :截止频率&#xff0c;单位&#xff1a; HZ 对低通滤波器进行离散化 一 后向差分法 变换公式为&#xff1a; s(1−z−1)/Ts​ Ts&#xff1a;采样频率 将变化公式带入传递函数&#xff0c;可得…

一文读懂滤波器的线性相位,全通滤波器,群延迟

一文读懂滤波器的线性相位&#xff0c;全通滤波器&#xff0c;群延迟 1. 延迟2. 全通滤波器3.相位延迟和群延迟4. 实际生活中的例子总结&#xff1a; 数字信号处理最常见的面试题&#xff0c;请简述FIR和IIR的区别。其中的一个区别是FIR可以方便地实现线性相位。那这个线性相位…

一阶RC低通滤波器的数学模型及算法实现

一阶RC低通滤波器的数学模型及算法实现 1. 一阶RC低通滤波器的连续域数学模型1.1 数学模型的推导1.2 频率特性1.3 物理作用 2. 一阶RC低通滤波器的算法推导2.1 离散化2.2 滤波系数 3. 一阶RC低通滤波器的C语言实现4. 缺点及改善方法4.1 缺点4.2 改善方法——动态调整滤波系数4.…

数字 一阶低通滤波器 详细分析

事件的起因是下图1&#xff0c;朋友偶然说到一阶低通滤波器&#xff0c;借此来详细介绍一阶低通滤波器的原理&#xff0c;并附上matlab仿真程序代码。图1中的一阶低通数字滤波器的公式为Eq(1)&#xff1a; y(n) q*x(n) (1-q)*y(n-1) Eq(1) 其中&#xff0c;y(n)表示当前…

【滤波器学习笔记】一阶RC低通滤波

一阶RC低通滤波 从模拟到数字 本文整理自网络、《匠人手记》等书籍文章 模拟电路低通滤波时域、频域软件低通滤波 典型电路 图1 典型RC电路 直流、交流、脉冲信号都可以用它 时域 电容电流&#xff1a; Icdqdtd(C∙Uo)dtCdUodt 基尔霍夫电压定律得&#xff1a; UiRCdUo…

一阶低通数字滤波

一阶低通滤波算法&#xff1a; 3、 一阶低通滤波优缺点 一阶低通滤波数学意义&#xff1a;一阶低通滤波法采用本次采样值与上次滤波输出值进行加权&#xff0c;得到有效滤波值&#xff0c;使得输出对输入有反馈作用。 优缺点&#xff1a;滤波系数越小&#xff0c;滤波结果越平稳…

MATLAB—FIR数字滤波器设计

目录&#xff1a; 1 FIR滤波器的原理2 FIR滤波器的特点2.1 相位特性2.1.1 偶对称2.1.2 奇对称 2.2 幅度特性 3 几种滤波器函数3.1 fir1()3.2 fir2()3.3 kaiserord()3.4 firpm() 4 仿真实例4.1 代码4.2 仿真分析 本文是基于MATLAB的数字滤波器设计&#xff0c;所有数据基于计算机…

窗函数法设计FIR中,如何选择窗函数和阶数N

在用窗函数法设计FIR滤波器时&#xff0c;给出了滤波器要求的具体指标&#xff0c;包括通带频率fp、阻带频率fs、通带波纹Rp和阻带衰减As等&#xff0c;有了这些指标后&#xff0c;是否什么窗函数都可以选择呢&#xff1f;答案是否定的。那么怎么选择窗函数呢&#xff1f;在本小…

一阶RC低通滤波器(二)

这篇文章补充下前面讲的一阶低通滤波器。在母线电压采样或是在电机的三相端电压采样时&#xff0c;往往是先分压&#xff0c;再经过RC低通滤波器。电路图如下&#xff1a; 1&#xff1a;先求输出和输入的关系&#xff08;Uao/Ua&#xff09; 从上式可以看出系统相当于一个典…

二阶有源滤波器设计

1引入 为什么要用有源二阶滤波器&#xff1f; (1)从有源来说 对于无源二阶低通滤波器&#xff1a; 其幅頻方程为&#xff1a; 我们从中可以看出其通带截止频率为 有其品质因子为0.372。 我们根据上图得到二阶无源低通滤波器的品质因子只有0.372&#xff0c;如果希望Q大于0.5…

滤波算法——均值滤波,中值滤波,一阶(αβ)滤波,卡尔曼滤波

滤波算法——均值滤波&#xff0c;中值滤波&#xff0c;一阶(αβ)滤波&#xff0c;卡尔曼滤波 因工作涉及到数据滤波(滤噪)处理&#xff0c;汇总了一些网上简单的滤波算法&#xff0c;方便日后查看。 滤波算法包括&#xff1a;均值滤波&#xff0c;中值滤波&#xff0c;一阶…

一阶滤波器

1. 一阶滤波算法的原理 一阶滤波&#xff0c;又叫一阶惯性滤波&#xff0c;或一阶低通滤波。是使用软件编程实现普通硬件RC低通滤波器的功能。 一阶低通滤波的算法公式为&#xff1a; Y(n)αX(n) (1-α)Y(n-1) 式中&#xff1a;α滤波系数&#xff1b;X(n)本次采样值&…

FIR数字滤波器设计

今天给大侠带来FIR数字滤波器设计&#xff0c;由于篇幅较长&#xff0c;分三篇。今天带来第三篇&#xff0c;FIR数字滤波器设计&#xff0c;包括窗函数法设计FIR滤波器、频率采样法设计FIR滤波器以及基于firls函数和remez函数的最优化方法设计FIR滤波器。话不多说&#xff0c;上…

一阶二阶数字滤波器笔记

数字滤波器 一阶数字滤波器时域分析频域分析数字化代码示例 二阶巴特沃斯低通滤波器S域和Z域的频率关系分析巴特沃斯滤波器举例说明代码示例 声明&#xff1a;感谢知乎大佬的文章&#xff0c;原文链接 数字滤波器实现方法是把滤波器所要完成的运算编成程序并让计算机执行,也就…

简单二阶滤波器截止频率的计算

最近刚好学习到这了&#xff0c;而我在网上查资料的时候却非常难找&#xff0c;不少资料讲解不够详细&#xff0c;所以经过我努力也为了为大家做点贡献的想法&#xff0c;以自己的见解写下这篇文章。废话不多说&#xff0c;先从一阶滤波器讲起。 一阶低通滤波器&#xff1a; …

如何确定插值滤波器的阶数

在信号处理中&#xff0c;滤波器的系数我们往往都是通过MATLAB来设计&#xff0c;只要我们知道滤波器的通带截止频率和阻带起始频率&#xff0c;就可以通过MATLAB中的fdatool&#xff08;在MATLAB2020中使用filterDesigner&#xff09;来设计滤波器了。 我们使用归一化的参数来…

标识符无效

表中存在该列&#xff0c;插入的时候却显示 标识符无效&#xff0c;使用dbsql插入报错&#xff0c;自己写入数据没有问题&#xff01; 查资料发现可能和列的大小写有关。这里强调sql一定用全大写来写避免不必要的麻烦&#xff01;但是我改过后发现并不是这个问题…… 问题已解…

ORA-00904 ID 标识符无效 解决方案

msg&#xff1a;"数据访问异常" dev&#xff1a;"ORA-00904&#xff1a;"ID"&#xff1a;标识符无效 ORA&#xff1a;即 Oracle 报错。 标识符无效是因为&#xff1a;SQL语句中&#xff0c;列名&#xff08;ID&#xff09;不在表中。解决方案&#x…