在函数中接受所有类型作为参数

Cod*_*sum 10 c++ arguments

我怎么能在C++中使一个函数接受每个Object,所以我可以给它数字,字符串或其他对象.我在C++方面表现不佳,我希望这不是一个完全愚蠢的问题......

编辑:好的,一个例子:如果你想尝试将std :: cout流包装到普通函数中,那么该函数应该能够接受所有东西 - 从浮点数上的整数到复杂的对象.我希望现在更清楚了!

Wal*_*ter 13

您可以为不同类型重载功能,即

size_t func(int);
size_t func(std::string);
Run Code Online (Sandbox Code Playgroud)

或者和/或另外,您可以提供一个函数模板,这是一种告诉编译器如何为任何特定类型生成函数的方法,例如

template<typename T>
size_t func(T const&) { return sizeof(T); }
Run Code Online (Sandbox Code Playgroud)

您可以使用更高级的技术(如SFINAE)来有效地重载这些模板函数,即为不同类型的类型使用不同的模板T(即整数类型,指针,内置类型,pod等).然后编译器将为func()它遇到的任何函数调用选择最合适的(如果有的话),如果这是一个模板,则生成一个适当的函数.这不需要重新编码.

一种完全不同的方法是使用通用擦除类型,例如boost::any,当函数需要在编码时解析期望的类型(而不是编译时):

size_t func(boost::any const&x)
{
  auto i = boost::any_cast<const int*>(x);
  if(i) return func(*i);
  // etc for other types, but this must be done at coding time!
}
Run Code Online (Sandbox Code Playgroud)


cdh*_*wie 5

您可以为此使用模板:

template <typename T>
void foo(T const & value)
{
    // value is of some type T, which can be any type at all.
}
Run Code Online (Sandbox Code Playgroud)

什么你其实可以做的价值可能相当有限不知道它的类型-这取决于你的函数的目标。(如果有人尝试使用导致该函数专业化格式错误的参数类型调用该函数,则您的模板函数将无法实例化,并且将是编译时错误。)