如何实现自己的可变参数函数,像printf()那样?
技术上,主要用到3个宏:va_arg, va_end, va_start.
void va_start(
va_list arg_ptr
); // (UNIX version)
void va_start(
va_list arg_ptr,
prev_param
); // (ANSI version)
type va_arg(
va_list arg_ptr,
type
);
void va_end(
va_list arg_ptr
);
用法类似于读目录操作
va_list varray:定义目录指针。 varray用来做handle取参数。
va_start: opendir()。 将varray和栈里面的实参对应起来。
va_arg: readdir()。 读下一个参数,并将varray递增。type是要读的参数的类型,根据它编译器就知道要递增多少byte了。(Question: 如果参数类型不知道怎么办?)
va_end: closedir()。 将varray置空。
思路:
要实现可变参数,callee必须知道参数个数。有两种方法实现:
1. 第一个参数包含参数个数信息。如printf(), 第一个参数字符串里有多少%?就说明有多少个参数。
2. 最后一个参数作为terminator。
如int average( int first, ... ),调用的时候用-1作为最后一个参数,表示参数列表结束。
printf( "Average is: %d/n", average( 2, 3, 4, -1 ) );
printf( "Average is: %d/n", average( 5, 7, 9, 11, -1 ) );
printf( "Average is: %d/n", average( -1 ) );
Reference:
http://msdn.microsoft.com/en-au/library/h1be630c(VS.80).aspx