stdarg.h头文件中va_start va_arg va_end解析
来源:互联网 发布:大数据相关技术介绍 编辑:程序博客网 时间:2024/06/05 18:02
stdarg.h头文件中va_start va_arg va_end解析
stdarg.h是C语言中C标准函数库的头文件,stdarg是由standard(标准) arguments(参数)简化而来,主要目的为让函数能够接收可变参数。其中主要涉及到 va_start va_arg va_end这三个函数,下面将主要通过一个例子来介绍这三个函数的作用。
总结:读取可变参数的过程其实就是在堆栈中,使用指针,遍历堆栈段中的参数列表,从低地址到高地址一个一个地把参数内容读出来的过程·(因为入栈是从高地址向低地址入栈,出栈就从低地址向高地址出栈,先入后出)
例(例子来自stdarg.h的百度百科)红色部分为自己理解内容
#include <stdio.h>
#include <stdarg.h>
/*函数功能: 输出所有int类型的参数,直到-1结束 */
void printargs(int arg1, ...) //好多资料认为可变参数里面必须为int型,个人认为是错误的
{
va_list ap;//va_list是一个数组/指针类型(参数列表),当该类型的对象作为参数传递时,它将被引用传递。
int i;
va_start(ap, arg1);//开始可变参数处理,得到第一个可变参数地址/指针,好多资料认为这里的arg1是可变参数的个数,个人认为是错误的
for (i = arg1; i != -1; i = va_arg(ap, int))//得到第一个可变参数的值,执行后ap指向下一个可变参数地址即将ap指针上移(int)大小地址
//注意:int i; i = va_arg(ap,int) 这里i的类型需和va_arg函数里面第二个参数的类型一致
printf("%d ", i);
va_end(ap);//置空ap,即ap=(void *)0;即释放链表
putchar('\n');
}
int main(void)
{
printargs(5, 2, 14, 84, 97, 15, 24, 48, -1);
printargs(84, 51, -1);
printargs(-1);
printargs(1, -1);
return 0;
}
这个程序产生输出:
5 2 14 84 97 15 24 48
84 51
1
阅读全文
0 0
- stdarg.h头文件中va_start va_arg va_end解析
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- stdarg.h中三个宏va_start ,va_arg和va_end
- 编写一个可变参数的C函数——头文件stdarg.h中宏va_start ,va_arg和va_end的应用
- 编写一个可变参数的C函数——头文件stdarg.h中宏va_start ,va_arg和va_end的应用
- stdarg.h中三个宏va_start ,va_arg和va_end的应用
- stdarg.h中三个宏va_start ,va_arg和va_end的应用
- stdarg.h中三个宏va_start ,va_arg\va_end及vsprintf 的应用
- stdarg.h中三个宏va_start ,va_arg和va_end的应用
- C可变长参数表问题---stdarg.h宏定义va_start,va_arg,va_end
- va_list va_start va_arg va_end解析
- C语言va_list,va_start,va_arg,va_end解析
- 容斥原理
- Yii2.0-图片上传扩展(异步加载缩略图) [扩展组件]
- jsonp跨域请求,常见的集中书写方式,及优缺点比较
- linux 网络设置基础知识整理复习(一)碰到的各种问题
- Maximum and Minimum Depth of Binary Tree 二叉树的最小最大深度 [java]
- stdarg.h头文件中va_start va_arg va_end解析
- Thread和Runnable的子类调用
- (方法)枚举2^k所有情况
- White matter hyperintensity and stroke lesion segmentation and differentiation using cnn_part2_2017
- reactwebAPP的各个页面之间的跳转以及footer相对应!
- K-D树小结
- 2017/8/8
- 动态规划 LCS 求两个序列A,B中全部的最长公共子序列
- unity嵌入 svn tools 整理