是否有一种非增强方法来创建具有可变参数的函数?我知道参数类型 参数的数量,它们是通常少于 5 个,都是同一类型。
我需要知道是否有办法不提供参数计数或以 null 结束参数列表。
我知道参数类型,它们通常少于 5 个。
如果它不会大于5
,那么简单的重载可能会起作用。调用从所有其他接受少于 5 个参数的重载中接受最大参数数量的重载,或定义一个工作(内部)函数,从重载中调用它。
如果可能,您可以为某些参数使用默认值,如果这有助于减少重载函数的数量。
在 C++11 中,您可以使用variadic-template。
对于最多 5 个相同类型的参数,简单的重载可以解决问题。
为了更通用,支持任意数量的相同类型的参数,只需传递一个集合,例如 a std::vector
。
有关在每次调用中即时构建此类集合的 C++03 技术,请参阅我的其他答案;对于 C++11,如果您不需要支持 Visual C++,则可以使用花括号初始化器列表作为实际参数。
cstdarg是你要找的吗?这是生成具有可变数量参数的函数的标准 C++ 方法。
您应该能够使用va_list实现传递变量参数。
作为一般的 C++03 解决方案,您可以提供一个 setter,它返回对调用它的对象的引用,以便可以再次调用它。然后再次。等等,称为链接。
它与 iostreams 用于operator<<
.
例如
#include <iostream>
#include <sstream>
#include <string>
using namespace std;
void foo( char const s[] )
{
cout << s << endl;
}
class StringBuilder
{
private:
string s_;
template< class Type >
string fastStringFrom( Type const& v )
{
stringstream stream;
stream << v;
return stream.str();
}
char const* fastStringFrom( char const* s )
{
return s;
}
string const& fastStringFrom( string const& s )
{
return s;
}
public:
template< class Type >
StringBuilder& operator<<( Type const& v )
{
s_ += fastStringFrom( v );
return *this; // Supports chaining.
}
operator string const& () const { return s_; }
operator char const* () const { return s_.c_str(); }
};
int main()
{
typedef StringBuilder S;
foo( S() << "6*7 = " << 6*7 << "." ); // Any number of arguments.
}
无需将参数值转换为文本,您只需执行所需的任何操作。例如,使用一组固定的可能类型,您可以将参数存储在集合中。
如果您不需要支持 Visual C++ 编译器,那么您也可以使用 C++11可变参数模板。
你可以:
f(const T& v1 = missing, const T& v2 = missing, ...) { if (v5 != missing) ...
new
,手动销毁等来支持没有默认构造函数的类型。(繁琐且更容易出错但更快)template <size_t N> void f(T (&data)[N]) { ... }
技巧让编译器自动为您提供数组大小)operator,
或之类的运算符为其提供额外的值operator<<