函数有时翻译为子程序。C语言中的函数就是一个完成某项特定任务的一小段代码。这段代码是有特殊的写法和调用方法的。C语言的程序其实是由无数个小的函数组合而成,也可以说:应该大的计算任务可以分解成若干个较小的函数完成。同时,一个函数如果能完成某项特定任务的话,这个函数也是可以复用的,提升了开发软件的效率。
在C语言中我们一般会见到两类函数:
C语言标准规定了一组函数,这些函数再有不同的编译器厂商根据标准进行实现,提供给程序员使用。这些函数组成了一个函数库,被称为标准库,这些函数也被称为库函数,这些库函数的使用,要包含对应的头文件。
其实自定义函数和库函数是一样的,形式如下:
ret_type fun_name(形式参数)//ret_type是函数的返回类型,fun_name是函数名
{
//函数体
}
函数的举例
//写一个加法函数,完成两个整型变量的相加
#include<stdio.h>
int Add(int x, int y)
{
int z=x+y;
return z;
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
int r=Add(a, b);//调用加法Add函数,求和的结果放在r中
printf("%d", r);
}
Add函数也可简化为
Add(int x, int y)
{
return x+y;
}
函数的参数部分需要交代清楚:参数个数,每个参数的类型,形参的名字叫啥
在函数的使用过程中,把函数的参数分为,实参和形参。
在上述代码中,调用Add函数时,传递给函数的参数a和b,称为实际参数,简称实参。
实际参数就是真实传递给函数的参数。
上面代码中,定义函数的时候,在函数名Add后的括号中写的x和y,称为形式参数,简称形参。
形式参数:如果只定义了Add函数,而不去调用的话,Add函数的参数x和y只是形式上的存在,不会向内存申请空间,不会真实存在,所以叫形式参数。形式参数只有在函数调用的过程中,为了存放实参传递过来的值,才向内存申请空间,这个过程叫做形参的实例化。
虽然实参是传递给形参的,但他们各自是独立的内存空间,修改形参不会影响实参。但数组做函数参数时,形参和实参申请的空间相同。公主王子们动手看看数组传参,形参申请到的空间和实参是否一样吧
通过Fn F11调试,即可验证,x和y确实得到了a和b的值,但是他们的地址不相同,所以可以理解为形参是实参的一份临时拷贝。
//写一个函数,将一个整形数组的内容全部置为-1,再写一个函数打印数组的内容。
#include<stdio.h>
int main()//主函数
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int sz = sizeof(arr) / sizeof(arr[1]); //数组个数
set_arr(arr,sz);//设置数组内容为-1
print_ar(arr,sz);//打印数组内容
return 0;
}
这里set_arr函数能对数组内容进行设置,就得把数组作为参数传递给函数(只需要函数名),同时函数内部在设置每个元素的时候,也得遍历数组,需要知道数组的元素个数。所以需要传递给set_arr传递2个参数,数组和数字的元素个数。同理可得也需要传递给print_arr 2个参数。
//自定义函数
void set_arr(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
arr[i] = -1;
}
}
void print_arr(int arr[], int sz)
{
for (int i = 0; i < sz; i++)
{
printf("%d", arr[i]);
printf("\n");
}
}
完整代码
#include<stdio.h>
//自定义函数
void set_arr(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
arr[i] = -1;
}
}
void print_arr(int arr[], int sz)
{
for (int i = 0; i < sz; i++)
{
printf("%d", arr[i]);
printf("\n");
}
}
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int sz = sizeof(arr) / sizeof(arr[1]); //数组个数
set_arr(arr,sz);//设置数组内容为-1
print_arr(arr,sz);//打印数组内容
return 0;
}
总结:函数传参的重要知识点