c语言宏函数可变参数 c++可变参数宏

C语言宏定义实现可变参数

__VA_ARGS__ 是一个可变参数的宏,这个可变参数的宏是新的C99规范中新增的。

创新互联公司于2013年成立,先为安义等服务建站,安义等地企业,进行企业商务咨询服务。为安义企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

GCC、VC2005开始支持。

#define CALCSUM(v, ...)   sum(v, __VA_ARGS__)

int sum(int num_args, ...)

{

int val = 0;

va_list ap;

int i;

va_start(ap, num_args);

for (i = 0; i num_args; i++)

{

val += va_arg(ap, int);

}

va_end(ap);

return val;

}

int main(void)

{

printf("10、20 和 30 的和 = %d\n", CALCSUM(3, 10, 20, 30));

printf("4、20、25 和 30 的和 = %d\n", CALCSUM(4, 4, 20, 25, 30));

return 0;

}

将函数定义成宏 参数类型怎样设置

需要借用C语言的VA_LIST 宏定义,及相关操作来实现可变参数。VA_LIST 所在头文件:#include stdarg.h,用法如下:(1)首先在函数里定义一具VA_LIST型的变量,这个变量是指向参数的指针;(2)然后用VA_START宏初始化刚定义的VA_LIST变量;(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型(如果函数有多个可变参数的,依次调用VA_ARG获取各个参数);(4)最后用VA_END宏结束可变参数的获取。以下是一个自定义打印接口的实现:pre t="code" l="cpp"int my_printf(const char *fmt, )//表示参数可变

{

va_list args;//定义va_list

static char gc_PrintfOutBuff[1000];

va_start(args, fmt);//初始化

vsnprintf((char *) gc_PrintfOutBuff, 1000, (char *) fmt, args);//这里没有使用VA_ARG取回单个变量,而是借用vsnprinf一次性读取。

va_end(args);//结束获取

puts("%s",(const char *)gc_PrintfOutBuff);//使用。

return 0;

}

c语言如何封装一个带有可变参数的方法?

需要借用C语言的VA_LIST 宏定义,及相关操作来实现可变参数。

VA_LIST 所在头文件:#include stdarg.h,用法如下:

(1)首先在函数里定义一具VA_LIST型的变量,这个变量是指向参数的指针;

(2)然后用VA_START宏初始化刚定义的VA_LIST变量;

(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型(如果函数有多个可变参数的,依次调用VA_ARG获取各个参数);

(4)最后用VA_END宏结束可变参数的获取。

以下是一个自定义打印接口的实现:

int my_printf(const char *fmt, ...)//...表示参数可变

{

va_list args;//定义va_list

static char gc_PrintfOutBuff[1000];

va_start(args, fmt);//初始化

vsnprintf((char *) gc_PrintfOutBuff, 1000, (char *) fmt, args);//这里没有使用VA_ARG取回单个变量,而是借用vsnprinf一次性读取。

va_end(args);//结束获取

puts("%s",(const char *)gc_PrintfOutBuff);//使用。

return 0;

}

c语言中函数可否改变参数值

#include

void

foo(int

x,

int

y,

int

z)

{

printf("x

=

%d

at

[%x]n",

x,

x);

printf("y

=

%d

at

[%x]n",

y,

y);

printf("z

=

%d

at

[%x]n",

z,

z);

}

int

main(int

argc,

char

*argv[])

{

foo(100,

200,

300);

return

0;

}

运行结果:

x

=

100

at

[bfe28760]

y

=

200

at

[bfe28764]

z

=

300

at

[bfe28768]

c程序栈底为高地址,栈顶为低地址,因此上面的实例可以说明函数参数入栈顺序的确是从右至左的。可到底为什么呢?查了一直些文献得知,参数入栈顺序是和具体编译器实现相关的。比如,pascal语言中参数就是从左到右入栈的,有些语言中还可以通过修饰符进行指定,如visual

c++.即然两种方式都可以,为什么c语言要选择从右至左呢?

进一步发现,pascal语言不支持可变长参数,而c语言支持这种特色,正是这个原因使得c语言函数参数入栈顺序为从右至左。具体原因为:c方式参数入栈顺序(从右至左)的好处就是可以动态变化参数个数。通过栈堆分析可知,自左向右的入栈方式,最前面的参数被压在栈底。除非知道参数个数,否则是无法通过栈指针的相对位移求得最左边的参数。这样就变成了左边参数的个数不确定,正好和动态参数个数的方向相反。

因此,c语言函数参数采用自右向左的入栈顺序,主要原因是为了支持可变长参数形式。换句话说,如果不支持这个特色,c语言完全和pascal一样,采用自左向右的参数入栈方式

c语言如何定义一个可变参数函数 如何调用其输入的参数 分别

有专门的宏,处理可变参

void va_start( va_list arg_ptr, prev_param );

type va_arg( va_list arg_ptr, type );

void va_end( va_list arg_ptr );

一个简单的例子

void simple_va_fun(int i, ...)

{

va_list arg_ptr;

int j=0;

va_start(arg_ptr, i);

j=va_arg(arg_ptr, int);

va_end(arg_ptr);

printf("i=%d j=%d\bn", i, j);

return;

}

int main()

{

simple_va_fun(1);

simple_va_fun(1,2);

simple_va_fun(1,200);

return 0;

}

C语言中可变参数宏的va_start(ap, v)

你需要明白的是va_系列函数的实现原理是根据栈指针来进行定位不定参数的位置,然后根据你的需要(注意是根据你的需要,并不是检测告诉你数据的类型与值),将数据的值给取出来。

所以va_start那里本质是为了得到当前的不定参数数据在栈中存放的位置指针,va_ap是根据你需要的类型(参数中传入数据的类型),来得到所需要的数据。


分享名称:c语言宏函数可变参数 c++可变参数宏
网站链接:http://pwwzsj.com/article/hpjohi.html