C语言可变形参是什么-定义长度可变的数组

C语言可变形参

  C语言允许定义参数数量可变的函数,这称为可变参数函数(variadic function)。这种函数需要固定数量的强制参数(mandatory argument),后面是数量可变的可选参数(optional argument)。

1.可变形参相关函数

复制#include void va_start(va_list ap, last); type va_arg(va_list ap, type); void va_end(va_list ap); void va_copy(va_list dest, va_list src);

 va_start完成ap指针初始化,以供va_arg和va_end后续使用,该函数必须先调用。参数last是变量参数列表前最后一个参数的名称;

va_arg实现下一个参数的类型和值的获取。参数ap是由va_start初始化的参数列表。对va_arg()的每次调用都会修改ap,以便获取下一个参数。参数类型type是一个指定的数据类型。

va_end将ap指向NULL。

va_copy将参数列表src复制到dest中,该函数在c99才有定义。

2.可变形参模仿printf函数

复制#include #include void my_printf(const char *fmt,…); int main() { my_printf(“%s\n”,”123456″); my_printf(“%d %%\n”,55); my_printf(“%f\n”,789.56); my_printf(“%c\n”,c); my_printf(“%ld,%lf\n”,1234567890123,45.789625); } void my_printf(const char *fmt,…) { va_list ap; va_start(ap,fmt);//ap=fmt char c,*s; int d; float f; long l; double b; while(*fmt) { if(*fmt!=%) { putchar(*fmt);//输出%前所有字符 } else { fmt++;//跳过% switch(*fmt) { case c://字符 c=(char )va_arg(ap,int);//字符存储时按int空间处理 fprintf(stdout,”%c”,c); break; case d://整数 d=va_arg(ap,int); fprintf(stdout,”%d”,d); break; case f://浮点数 f=(float)va_arg(ap,double);//浮点数据处理时按double处理 fprintf(stdout,”%f”,f); break; case %://%% putchar(*fmt); break; case s://字符串 s=va_arg(ap,char *); fprintf(stdout,”%s”,s); break; case l: fmt++; if(*fmt==d)//长整形%ld { l=va_arg(ap,long); fprintf(stdout,”%ld”,l); } else if(*fmt==f)//双精度浮点型%lf { b=va_arg(ap,double); fprintf(stdout,”%lf”,b); } break; } } fmt++; } va_end(ap);//ap=NULL }

  运行效果:

复制[wbyq@wbyq 0414work]$ gcc main.c [wbyq@wbyq 0414work]$ ./a.out 123456 55 % 789.559998 c 1234567890123,45.789625 审核编辑 黄昊宇

免责声明:文章内容来自互联网,本站不对其真实性负责,也不承担任何法律责任,如有侵权等情况,请与本站联系删除。
转载请注明出处:C语言可变形参是什么-定义长度可变的数组 https://www.yhzz.com.cn/a/8274.html

上一篇 2023-04-19 11:45:30
下一篇 2023-04-19 11:48:11

相关推荐

联系云恒

在线留言: 我要留言
客服热线:400-600-0310
工作时间:周一至周六,08:30-17:30,节假日休息。