C语言非常道 6.4习题解答



关于 #include "stdarg.h" 相关知识小结:

函数:tppedef va_list char * ;
va_list al;
va_start(al, fmt) 使 al 指向变参函数中最后一个已知参数(从右往左数的第一个已知参数)
va_arg(两个参数) ,第一个参数是:被声明为 va_list 类型的变量,第二个参数则是类型名,要想获得每一个变参,最重要的是知道它的类型,在程序翻译时,这个宏被扩展为一个表达式,所以它可以直接作为运算符 += 的右操作数

开始,令va_list类型的变量ap指向最后一个已知参数,此后,每调用一次va_arg,都会使ap指向下一个参数(变参)并取得(计算出)他的值。
va_end(); 使用va_start();后一定要使用va_end();才能保证返回时一切正常

书P190上下,例程以及例题结合理解。

计算传入参数的加和,普通的写法

使用 #include " stdarg.h "

计算传入参数的加和

所调用的函数在主函数之前,利用函数定义的方式声明

c 复制代码
#include "stdio.h"
#include "stdarg.h"

int sum_ints(unsigned int count,...)
{
	int sum = 0;
	va_list ap; 
	va_start(ap,count);
    while(count--) 
    	sum += va_arg(ap,int);         //第一个参数是变量,第二个参数是变量的类型
    va_end(ap);
    return sum;                        //return 最终返回值变量类型和函数类型必须是统一的
}

int main()
{ 
    int x,y;
	x = sum_ints(2,100,200);
	y = sum_ints(0);
	printf("%d, %d\n",x,y);
	
	return 0;
}

函数定义在主函数之后,并且利用普通函数类型定义的方式声明子函数

感觉在这个程序里面这样去定义就是多此一举,但是如果在一个这种类型很多的函数里面,就会非常方便

c 复制代码
#include "stdio.h"
#include "stdarg.h"

typedef int F(unsigned int count,...);

int main()
{ 
    F sum_ints;
    int x,y;
	x = sum_ints(2,100,200);
	y = sum_ints(0);
	printf("%d, %d\n",x,y);
	
	return 0;
}
int sum_ints(unsigned int count,...)
{
	int sum = 0;
	va_list ap; 
	va_start(ap,count);
    while(count--) 
    	sum += va_arg(ap,int);         //第一个参数是变量,第二个参数是变量的类型
    va_end(ap);
    return sum;
}
相关推荐
C语言小火车3 小时前
野指针:C/C++内存管理的“幽灵陷阱”与系统化规避策略
c语言·c++·学习·指针
凤年徐3 小时前
【数据结构】时间复杂度和空间复杂度
c语言·数据结构·c++·笔记·算法
鑫宇吖3 小时前
Polyspace作为MISRA-C合规性检查工具,其检查规则会根据目标C语言标准(C90或C99)动态调整限值要求。
c语言·嵌入式·c99·c90·polyspace·misra-c合规性检查
钮钴禄·爱因斯晨4 小时前
C语言 | 函数核心机制深度解构:从底层架构到工程化实践
c语言·开发语言·数据结构
爱学习的小邓同学5 小时前
数据结构 --- 队列
c语言·数据结构
啟明起鸣11 小时前
【网络编程】简易的 p2p 模型,实现两台虚拟机之间的简单点对点通信,并以小见大观察 TCP 协议的具体运行
c语言·网络·tcp/ip·p2p
秋说16 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法
芯岭技术18 小时前
MS32C001-C单片机,32位ARM M0+内核,宽电压、低功耗、小封装。
c语言·arm开发·单片机
minji...19 小时前
数据结构 算法复杂度(1)
c语言·开发语言·数据结构·算法
秋说20 小时前
【PTA数据结构 | C语言版】在顺序表 list 的第 i 个位置上插入元素 x
c语言·数据结构·list