标签:
VA_LIST 是在C语言中解决变参问题的一组宏,定义在<stdarg.h>头文件下。
VA_LIST的用法:
(1)首先在函数里定义VA_LIST型的变量,这个变量是指向参数的指针
(2)然后用VA_START宏初始化变量刚定义的VA_LIST变量,这个宏的第二个参数是第一个可变参数的前一个参数,是一个固定的参数。
(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型。
(4)最后用VA_END宏结束可变参数的获取。然后你就可以在函数里使用第二个参数了。如果函数有多个可变参数的,依次调用VA_ARG获取各个参数。
- #include<stdio.h>
- #include <stdarg.h>
-
- void arg_cnt(int cnt, ...)
- {
- int value=0;
- int i=0;
- int arg_cnt=cnt;
- va_list arg_ptr;
- va_start(arg_ptr, cnt);
- for(i = 0; i < cnt; i++)
- {
- value = va_arg(arg_ptr,int);
- printf("value%d=%d\n", i+1, value);
- }
- va_end(arg_ptr);
- }
-
- int main(void)
- {
- arg_cnt(5,1,2,3,4,5);
- return 0;
- }
运行上面的程序:
value1=1
value2=2
value3=3
value4=4
value5=5
你发现这个程序有什么不方便的地方了吗?
对!就是要在第一个参数指定可变参数的数量,就是arg_cnt函数中的cnt变量,
如果我在main中调用
- <span style="font-size:10px;">arg_cnt(6,1,2,3,4,5);</span>
那么结果就是没法预测了。
下面再介绍一个vsnprintf函数,该函数支持可变参数,说明如下:
头文件:
#include <stdarg.h>
函数声明:
int vsnprintf(char *buffer, size_t max_count, const char *format, va_list vArgList);
参数说明:
char *buffer [out],把生成的格式化的字符串存放在这里.
size_t max_count [in], buffer可接受的最大字节数,防止产生数组越界.
const char *format [in], 格式化字符串
va_list vArgList [in], va_list变量. va:variable-argument:可变参数
用法类似于vsprintf,只不过加了max_count的限制.
返回值说明:
如果成功调用此函数,返回写到buffer中的字符的个数(不包括结尾的‘\0‘)。snprintf和vsnprintf函数不能够写多于size大小(包括结尾的‘0‘)的字节数。如果输出因为以上原因被截断,返回成功写入buffer的字符数(不包括结尾的‘\0‘),如果有足够的内存空间的话。所以,如果返回值等于size或者大于size,表示输出到buffer的字符被截断,如果输出过程中遇到错误,则返回一个负数。
- #include<stdio.h>
- #include <stdarg.h>
-
- #define bufsize 80
- char buffer[bufsize];
-
- int vspf(char *fmt, ...)
- {
- va_list argptr;
- int cnt;
- va_start(argptr, fmt);
- cnt = vsnprintf(buffer,bufsize ,fmt, argptr);
- va_end(argptr);
- return(cnt);
- }
-
- int main(void)
- {
- int inumber = 30;
- float fnumber = 90.0;
- char string[4] = "abc";
- int cnt = 0;
- cnt = vspf("%d %f %s", inumber, fnumber, string);
- printf("%s\n", buffer);
- printf("cnt=%d\n", cnt);
- return 0;
- }
执行结果如下:
30 90.000000 abc
cnt=16
宏可变参数列表
标签:
原文地址:http://www.cnblogs.com/QingCHOW/p/4603749.html