C语言中函数分为库函数和自定义函数。
1.库函数
使用库函数,必须得包含头文件,就比如使用printf函数和scanf函数,就得包含头文件<stdio.h>。
2.自定义函数
ret_type fun_name(形式参数)
{
函数体;
}
ret_type:函数的返回类型。
fun_name:函数名,根据函数的功能,函数名要取得有意义。
函数的参数是void表示没有参数,如果有参数,就要交代参数的类型、名字和参数个数。
函数在设计的时候遵循高凝聚,低耦合的原则,要保证函数的功能尽可能的单一,对其他的依赖性低。
就比如我想写一个函数,让它来帮我实现减法的功能。
#include <stdio.h>
int sub(int x, int y)//x和y是形参
{
int z = 0;
z = x - y;
return z;
}
int main()
{
int a = 6;
int b = 3;
int c = sub(a, b);//a和b是实参
printf("%d\n", c);
return 0;
}
3.return语句
使用return语句是需要注意:
*return后面可以是一个数值或者一个表达式或者什么都没有,返回空时,就可以写成return;。
*函数返回类型和return返回类型不一样的话,系统会自动将返回的值转换为函数返回类型。
*return语句执行后,后面的代码不再执行。
*如果函数中存在分支语句的话得保证每种情况下都有return返回。
4.实参和形参
实参:真实传递给函数的参数,上述代码中的a和b就是实参。
形参:如果不去调用的话,形参就只是形式上存在,不会向内存申请空间,它在函数调用完成后会自动销毁。上述代码中的x和y就是形参。
传值调用:是把实参的数值传递给形参,形参是实参的一份临时拷贝,对形参的修改不会影响实参。
传址调用:是把实参的地址传递给形参,操作形参可以对这块地址的内存单元进行修改,从而可以改变实参。
5.数组做函数参数
数组做函数参数传参时,需要传递2个参数,数组名和数组元素个数,这样就可以遍历数组打印数组的每一个元素。
比如:设计一个函数打印数组的每一个元素
void print(int arr[], int size)
{
for (int i = 0; i < size; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[5] = { 1,2,3,4,5 };
int size = sizeof(arr) / sizeof(arr[0]);//sizeof()求的是操作数所在内存的大小,单位是字节
print(arr, size);
return 0;
}
数组传参的重要知识6.点:
*形参和实参个数要相同。
*形参和实参的名字可以相同。
*实参和形参都可以写成数组的形式。
*形参是一维数组,数组大小可以省略;形参是二维数组,行可以省略,但是列不可以省略。
*形参操作的数组和实参是同一个数组,所以数组传参时是不会重新创建数组的。
6.函数的定义和声明
*在函数调用的时候,一定要先声明后使用。
*函数的定义是一种特殊的声明,但是必须得保证函数的定义放在使用之前。
void is_leap_year(int year);//函数的声明
int main()
{
int year = 0;
scanf("%d", &year);
is_leap_year(year);//函数的调用
return 0;
}
void is_leap_year(int year)//函数的定义
{
if (year % 4 == 0 && year % 100 == 0)
printf("%d是闰年\n", year);
else if (year % 400 == 0)
printf("%d是闰年\n", year);
else
printf("%d不是闰年\n", year);
}
家人们,如果本篇博客对你有帮助的话,帮我点个赞吧!