将一个函数作为参数传递给另一个函数
Passing a function as an argument to another function
为什么这样的函数可以
typedef std::vector<someclass> infocontainer;
double function2(const infocontainer&);
void function1(std::ostream&, const std::string&, double function2(const infocontainer&), const infocontainer, const infocontainer);
在主运行中调用时运行正常
function1(std::cout, "astring", function2, did, didnt);
但是当 function2 有第二个参数时,它会产生一个错误。
double function2(const infocontainer&, std::string&);
void function1(std::ostream&, const std::string&, double function2(const infocontainer&, const std::string&), const infocontainer, const infocontainer);
主要
function1(std::cout, "astring", function2, did, didnt);
candidate function not viable: no known conversion from 'double (const infocontainer &, const
std::string &)' to 'double (*)(const infocontainer &, std::string &)' for 3rd argument
"no known conversion from"
double (const infocontainer &, const std::string &)
"到"
double (*)(const infocontainer &, std::string &)
区别在于const
到第二个参数。您可能认为该函数被定义为double function2(const infocontainer&, const std::string&);
但您的编译器不同意。
因为您发布的代码与您尝试编译的代码不同。
下一行
void function1(std::ostream&, const std::string&, double function2(const infocontainer&, const std::string&), const infocontainer, const infocontainer);
在您尝试编译的代码的第三个参数中std::string &
之前缺少const
。
typedef
是你的函数指针的朋友。
该typedef
将减少很多问题,尤其是在为函数指定参数时。
例:
typedef double (*Pointer_To_One_Argument_Function)(const infocontainer&);
typedef double (*Pointer_To_Two_Argument_Function)(const infocontainer&, std::string&);
void function1A(std::ostream&, const std::string&, Pointer_To_One_Argument_Function, const infocontainer, const infocontainer);
void function1B(std::ostream&, const std::string&, Pointer_To_Two_Argument_Function, const infocontainer, const infocontainer);
在上面的示例中,typedef
可以使声明更具可读性。
此外,如果选择更改函数指针的参数数量或类型,则更改参数的类型会更容易。
至于您的问题,请检查双参数函数指针示例中函数指针的语法。
替代:函数对象(函子)
C++语言不是对函数指针使用复杂或复杂的语法,而是提供了另一种选择:函数对象。
函数对象是具有overloaded operator()
的class
或struct
。
例:
struct Function_Object_One_Parameter
{
virtual double operator()(const infocontainer&) = 0;
};
struct Function_Object_Two_Parameter
{
virtual double operator()(const infocontainer&, std::string&) = 0;
};
void function1C(std::ostream&, const std::string&, Function_Object_One_Parameter& f1, const infocontainer ic, const infocontainer)
{
// ...
f1(ic);
// ...
}
void function1D(std::ostream&, const std::string& s, Function_Object_Two_Parameter& f2, const infocontainer ic, const infocontainer)
{
// ...
f2(ic, s);
// ...
}
要使用此模式,请声明派生自Function_Object_One_Parameter
或Function_Object_Two_Parameter
的函数:
struct Happy_Function_One
: public Function_Object_One_Parameter
{
double operator()(const infocontainer&)
{
std::cout << "Happy" << std::endl;
return 3.14159267;
}
}
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 修改函数中的指针(将另一个指针作为参数传递)
- 如何将指针从一个void函数传递到另一个C++
- 如何从另一个文件继承私有成员变量和公共函数
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- C++-我可以创建另一个类的成员并在构造函数中使用它吗
- 如何在C++中将函数发送到另一个进程
- 如何在qt中从另一个类调用函数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 在作为静态成员包含在另一个类中的类的构造函数中使用 cout
- 将 N-arg 函数包装到另一个函数中
- 为什么我的模板化函数需要从一个迭代器转换到另一个迭代器?
- C++重载函数,一个采用基类的参数,另一个采用派生类的参数
- C++从另一个函数退出函数
- 为什么我不能在主函数之外定义一个类的对象(它继承了另一个类)?
- 在一个类中使用另一个类中的函数,而不在 c++ 中使用继承
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?