C++参数中的函数传递给另一个函数
C++ passing function in argument to another function
我正在尝试将函数传递给函数,声明看起来像
double fun1(const double* ang, std::function<double(double)> f1)
在main()
中,我正在创建函数指针并将其指向另一个函数为
std::function<double(double)> f2 = &fun5; //line1
和调用函数fun1
为
double x = fun1(&a,f2);
这行得通。但是,如果我调用函数为
double x = fun1(&a,&f2);
,它给出错误为
无法将"&f2"从"std::function*"转换为"std::function
创建引用在line1
工作,但使用引用调用函数不起作用。知道为什么会这样吗?
-
fun5
是一个函数 -
&fun5
是指向以下类型的函数的指针:double (*)(double)
-
f2
是一个函子对象,具体类型为:function<double(double)>
-
&f2
是这个函子对象的地址,它的类型是:function<double(double)>*
因为fun1
期望函子对象向它传递指向函子对象的指针是非法的。如果这更简单,请从int
的角度考虑这个问题。例如,如果我有一个函数:void foo(int arg)
,并且我有一个我不能做的int bar
:
foo(&bar)
这简直就是arg
通过int*
,这显然是违法的。必须发生的是:
foo(bar)
同样,您的函数需要一个函子对象。您需要将函子对象而不是指针传递给它,因此:
fun1(&a, f2)
首先让我们了解场景是什么,首先你创建了 f2,它是 &fun5,所以基本上你已经创建了 fun5 的别名,即 f2,现在根据您的函数参数,第二个参数需要像 f2 这样的函数,您在第一种情况下已经传递,但在第二种情况下,您需要有一个名为 pointer 的特殊变量来指向您传递的引用/地址,因此修改*某物的第二个参数和您的第二种情况可以正常工作。
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 修改函数中的指针(将另一个指针作为参数传递)
- 如何将指针从一个void函数传递到另一个C++
- 如何从另一个文件继承私有成员变量和公共函数
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- C++-我可以创建另一个类的成员并在构造函数中使用它吗
- 如何在C++中将函数发送到另一个进程
- 如何在qt中从另一个类调用函数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 在作为静态成员包含在另一个类中的类的构造函数中使用 cout
- 将 N-arg 函数包装到另一个函数中
- 为什么我的模板化函数需要从一个迭代器转换到另一个迭代器?
- C++重载函数,一个采用基类的参数,另一个采用派生类的参数
- C++从另一个函数退出函数
- 为什么我不能在主函数之外定义一个类的对象(它继承了另一个类)?
- 在一个类中使用另一个类中的函数,而不在 c++ 中使用继承
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?