C 参数个数可变函数举例

本文详细解读了C语言中可变参数函数的栈帧布局机制,通过具体代码实例展示了如何实现并使用可变参数函数。包括函数参数的传递顺序、内存布局及调用过程,旨在帮助开发者更深入地理解C语言底层实现细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      本来是想基于arm上实现printf函数,该函数参数类型不固定、个数也不固定,于是有点好奇,C语言是如何实现的。在看懂下面函数之前,必须了解一个问题,就是调用一个函数时,压入堆栈的数据是哪些排列的顺序如何。

      在进程中,堆栈地址从高往低分配的。调用函数时,压入堆栈的数据排列格式如下:

  1. 最后一个可变参数
  2. 倒数第二个可变参数
  3. ...
  4. 第一个可变参数
  5. 固定参数(这里假设固定参数为一个)
  6. 函数返回地址
  7. 函数代码段

#include<stdio.h>
#include<stdarg.h>
int sum(int n, ...)              //n表示可变参数的个数 
{              
	int sum=0,temp=0,i=0;
	va_list ap;     
	va_start(ap, n);             //指向第一个可选参数
	for(i = 0; i < n; i++) 
	{
		temp = va_arg(ap,int);   //取出类型为int可选参数的值,并且指向下一个可选参数
		sum=sum+temp;
	}
	va_end(ap);                  //关闭,相当于把ap指针的值置为NULL                   
	return sum;
}

int main() 
{
	printf("%d\n",sum(5,10,20,30,40,50));
	printf("%d\n",sum(2,10,30));
}

      程序运行效果图如下:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值