第7章,函数

函数

函数定义

K&R 和ANSI有差别

return expression;

return 语句允许你从函数体的任何位置返回,并不一定要在函数体的末尾。expression可以省略,直接来一个return ;这个时候函数的类型就声明为void;

函数声明

1、原型

(提前判断我们函数调用正确与否的方法)

方式一:

方式二:

如果函数的原型同时也被#include指令包含到定义函数的文件中,编译器还可以确认函数原型域函数定义是否匹配。

2、函数的缺省认定

对于无法见到函数原型的情况,编译器会假定在这个函数的调用时参数的类型和数量是正确的,它同时会假定函数将返回一个整形值。对于哪些返回值并非整形的函数而言,这种隐式的认定常常导致错误。

函数的参数

C函数的所有参数均以“按值调用”方式进行传递,这意味着函数将获得参数值的一份拷贝。这里需明确的是函数传递数组名的时候实际上传递的是数组的指针,这个值是一份指针的拷贝,所以可以影响到原数组。

ADT和黑盒

如下7.5a和7.5b文件

可变参数列表

1、stdarg宏

/*

**大凡子写的可变参数的demo,用于计算指定数量的值的平均值

*/

#include

float average(int n_values,...)

{

va_list var_arg;

int count;

float sum=0;

/*

**1、初始化va_list变量

*/

va_start(var_arg,n_values);

for(count=0;count

{

/*

**2、通过指定参数类型,依次访问可变按参数

*/

sum +=va_arg(var_arg,int);

}

/*

**3、访问完毕最后一个可变参数后,需要va_end

*/

va_end(var_arg);

return sum/n_values;

}

void main()

{

float a;

a=average(8,1,2,3,4,5,6,7,8);

printf("%f\n",a);

}

2、可变参数的限制

补充:对于哪些没有原型的函数,传递给函数的实参将进行缺省参数提升;char和short类型的实参转换为int,float类型的实参转换为double类型。

你可能感兴趣的:(第7章,函数)