首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么要在for循环中声明va_list?

在for循环中声明va_list是为了在循环中重复使用可变参数列表。

可变参数列表是一种特殊的参数类型,允许函数接受不定数量的参数。va_list是一个类型,用于存储可变参数列表的信息。在使用可变参数列表之前,我们需要使用宏va_start初始化va_list。而在每次使用完可变参数列表后,我们需要使用宏va_end清理va_list。在for循环中声明va_list可以确保每次循环都拥有独立的可变参数列表,避免了多次循环之间的参数干扰。

除了在循环中重复使用可变参数列表,还有一些其他情况可能需要在for循环中声明va_list。例如,当我们需要遍历一个包含可变参数的数据结构时,可以在for循环中声明va_list来逐个访问参数。

总之,为了在for循环中重复使用可变参数列表,我们需要在每次循环中声明va_list。这样可以确保每次循环都拥有独立的可变参数列表,避免了参数干扰。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • va_start va_arg va_end 的原理与实例

    func( Type para1, Type para2, Type para3, ... ) {       /****** Step 1 ******/       va_list ap;       va_start( ap, para3 ); //一定要“...”之前的那个参数**ap指向para后的第一个可变参数。       /****** Step 2 ******/       //此时ap指向第一个可变参数       //调用va_arg取得里面的值       Type xx = va_arg( ap, Type );        //Type一定要相同,如:       //char *p = va_arg( ap, char *);       //int i = va_arg( ap, int );       //如果有多个参数继续调用va_arg       /****** Step 3 ******/       va_end(ap); //For robust! } ◎研究: typedef char *    va_list;//va_list 等价于char*即字符指针。 #define va_start _crt_va_start//注意下面的替代。 #define va_arg _crt_va_arg #define va_end _crt_va_end #define  _crt_va_start(ap,v)    ( ap = (va_list)_ADDRESSOF(v) + _INTSIZEOF(v) ) #define _crt_va_arg(ap,t)      ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) ) #define _crt_va_end(ap)        ( ap = (va_list)0 )  va_list argptr; C语言的函数是从右向左压入堆栈的,调用va_start后, 按定义的宏运算,_ADDRESSOF得到v所在的地址,然后这个 地址加上v的大小,则使ap指向第一个可变参数如图:          栈底 高地址     | .......          | 函数返回地址     | .......           | 函数最后一个参数     | ....                            | 函数第一个可变参数       <--va_start后ap指向      | 函数最后一个固定参数     | 函数第一个固定参数      栈顶 低地址 然后,用va_arg()取得类型t的可变参数值, 先是让ap指向下一个参数: ap += _INTSIZEOF(t),然后在减去_INTSIZEOF(t),使得表达式结果为 ap之前的值,即当前需要得到的参数的地址,强制转换成指向此参数的 类型的指针,然后用*取值 最后,用va_end(ap),给ap初始化,保持健壮性。 example:(chenguiming) #include    <stdio.h>       #include    <ctype.h>       #include<stdlib.h>       #include    <stdarg.h>       int    average(    int    first,    ...    )      //变参数函数,C++里也有  **…表明后面有好多可变的参数。     {             int    count=0,i=first,sum=0;             va_list    maker;           //va_list    类型数据可以保存函数的所有参数,做为一个列表一样保存。Va_list即是char*表明maker是一个字符型的指针。             va_start(maker,first);    //设置列表的起始位置   **frist只是和maker在一起做参数,这并不说明maker指向frist而是指向first之后的第一个可变的参数,而frist是作为一个固定参数,因为它在…之前。这时候frist指向3。          while(i!=-1)             {             sum+=i;             count++;             i=va_arg(maker,int);//返回maker列表的当前值,并指向列表的下

    03

    我的女神——简洁实用的iOS代码调试框架 原

    这篇博客的起源是接手了公司的一个已经完成的项目,来做代码优化,项目工程很大,并且引入了很多公司内部的SDK,要搞清楚公司内部的这套框架,的确不是件容易的事,并且由于这个项目是多人开发的,在调试阶段会打印出巨量的调试信息,使得浏览有用信息变的十分困难,更加恐怖的是,很多信息是SDK中的调试打印,将这些都进行注销是非常费劲甚至不可能的事,于是便有了这样一些需求:首先,我需要清楚了解各个controller之间的跳转关系,需要快速的弄清每个stroyBoard中各个controller的来龙去脉,其次,我想在不改变其他人的调试代码的情况下,屏蔽冗余的log信息,让我的调试数据更加清晰明了。于是我想到了如下的解决方案,同样,如果你有更好的方案或者你知道的优秀的解决办法,请告知我,十分感谢。

    01
    领券