也谈可变参数
最近,自己搞了个小程序。要用到可变参数
为方便以简单代码陈列如下:
template <class T>
T t_Max(const T& arg, ...)
{
va_list arg_ptr;
va_start(arg_ptr, arg);
T data = arg
while (data != (T)(NULL))
{
data = va_arg(arg_ptr, T);
...//使用“ <”比较代码,略
}
va_end(arg_ptr);
return data;
}
这个函数想实现求最大值
普通类型比如:
cout < <t_Max( '1 ', '2 ', '4 ', '3 ');
cout < <t_Max(1, 3, 55, 3, 45);
都能够调试通过
而其他类型,例如,重载过 <运算符的自定义类就不可以,必须指定参数的结束标志
class User
{
public:
......
};
User a, b, c, d;
User t = t_Max(a, b, c, d, NULL);
必须手动添加上。
使用宏定义,#define MAX(argv) (t_Max(argv##, NULL))
也是不行的,看似正确,仔细分析就不对了
请教各位,如果如何实现这样
t_Max(T const& arg, ...)
{
}
Max(T const& arg, ...)
{
return t_Max(arg, ..., NULL);
}
怎样实现类似的功能。
欢迎讨论
[解决办法]
有必要搞可变参数么,放入一个数组/vector,在数组里搜索最大值就可以了。
[解决办法]
没有结束参数你能通过纯属巧合,是危险的
[解决办法]
鼓励一下
当然了,能走捷径尽量少绕弯路,这是原则[用最简单的方法解决最复杂的问题]
当然处于兴趣搞搞,无可厚非
[解决办法]
同时传递100个参数貌似函数设计的结构有问题
[解决办法]
还是用max_element方便一些.
可变参数进栈的时候,无法预料是什么进去了.
[解决办法]
boost库的format提供了一种可变参数函数的替代方案:
string s=format( "i am {0}, you are {1}... ") % "i " % "you ";
这种方法通过重载%操作符实现任意长度的类型安全的printf。同样的原理可以用在其他地方。
不过,类型安全可变参数函数的终极解决方案还是可变类型参数的模板:
template <typename... Args> void eat(Args... args);
这个特性有望进入下一个C++标准(C++0x)中。
期待中...
[解决办法]
下面的文字和代码摘自C++提案《Variadic Templates (Revision 3)》(N2080),演示了如何使用可变模板参数实现类型安全的printf():
Variadic function templates allow us to express a type-safe printf() that works for non-POD types. The following code uses variadic templates to implement a C++-friendly, type-safe printf():
void printf(const char* s) {
while (*s) {
if (*s == ’%’ && *++s != ’%’)
throw std::runtime error(”invalid format string: missing arguments”);
std::cout < < *s++;
}
}
template <typename T, typename... Args>
void printf(const char* s, T value, Args... args) {
while (*s) {
if (*s == ’% && *++s != ’%’) {
std::cout < < value;
return printf(++s, args...);
}
std::cout < < *s++;
}
throw std::runtime error(”extra arguments provided to printf”);
}
代码中还使用了函数模板和函数的混合递归展开。