某些情况下希望函数的参数个数可以根据需要确定。典型的例子有大家熟悉的函数printf()、scanf()和系统调用调用execl()等。那么它们是怎样实现的呢?C编译器通常提供了一系列处理这种情况的宏,有va_start、va_arg和va_end等。
stdarg.h中查到如下宏定义(不同的os定义方法可能不同):
typedef int *va_list[1];//va_list 变量类型定义
#define va_start(ap, parmN) (void)(*(ap) = __va_start(parmN))
#define va_arg(ap, type) __va_arg(*(ap), type)//取可变参数的内容
#define va_end(ap) ((void)(*(ap) = 0))
va_start功能:将ap指向可变参数列表的首地址;
va_arg功能:返回当前参数,并使ap指向参数列表的写一个参数;
va_end功能:是ap指针为空,作用是增强程序的强壮性。
一个可变参数的函数例子:
#include < stdio.h >;
#include < string.h >;
#include < stdarg.h >;
/* 函数原型声明,至少需要一个确定的参数,
注意括号内的省略号 */
int demo( char *, ... );
void main( void )
{
demo("DEMO", "This", "is", "a", "demo!", "\0";
}
/* ANSI标准形式的声明方式,括号内的省略号表示可选参数 */
int demo( char *msg, ... )
{
va_list argp; /* 定义保存函数参数的结构 */
int argno = 0; /* 纪录参数个数 */
char *para; /* 存放取出的字符串参数 */
/* argp指向传入的第一个可选参数,
msg是最后一个确定的参数 */
va_start( argp, msg );
while (1) {
para = va_arg( argp, char *); /*
取出当前的参数,类型为char *. */
if ( strcmp( para, "\0" == 0 )
/* 采用空串指示参数输入结束 */
break;
printf("arameter #%d is: %s\n", argno, para);
argno++;
}
va_end( argp ); /* 将argp置为NULL */
return 0;
}
阅读(839) | 评论(0) | 转发(0) |