函数分为两类,一类是库函数(我们直接引用头文件就可以调用),另一类是自定义函数(由我们自己定义相应功能,并调用)
以下所介绍的是自定义函数
- 函数的组成
自定义函数基本组成
// ret_type 函数的返回类型
// fun_name 函数名
// paral x 函数的参数
// {}内的为函数体,在里面添加语句实现功能
ret_type fun_name ( paral x )
{
//功能语句
};
例如 自定义函数找出两个函数中最大值
// 一般函数要先定义在调用(即第一部分在第二部分之前),若第二部分在第一部分之前,要用先声明才可以
//使用该函数,即高速编译器有一个函数叫什么,参数是什么,返回类型是什么,如下所示
int get_max(int x, int y);//函数声明
//第一部分
int get_max( int x, int y )//在主函数中传递过来的数是,整形,所以要定义两个int 形参来接受
{
int z=0;
if (x>y)
return z=x;
else
return z=y;
}
//第二部分
main()
{
int a = 10;
int b = 20;
int max = get_max(a,b);//调用函数get_max
printf(“max=%d,” max);
return 0;
}
- 函数的参数
参数分为两类:实际参数(实参)和形式参数(形参)。
实际参数:真实传递给函数的参数,即为实参。可以是常量,变量,表达式,函数等,无论实参是何种类型,在进行函数调用时,他们必需都有确定的值,以便将这些值传递给形参。调用函数时传递的值就是形参。
形式参数:函数名后括号里的变量。形参只有在函数被调用时才会实例化(分配内存单元),其生命在函数完成调用就销毁了。所以形参只在函数中有效。
void swap(int,x, int y);//xy就是形参
{
}
mian()
{
swap (a, b);//ab就是实参
return 0;
}
-
函数调用
调用分为传值调用
和传址调用
传值调用,就是实参将数值传递给形参。函数形参和实参分别有不同的内存块,对形参修改不会影响到实参。
传址调用,就是把函数外部创建变量的内存地址传递给函数参数。这种传参方式可以让函数和函数外的变量建立起真正的联系,在函数在函数内部可以直接操作函数外部变量。 -
函数的嵌套和链式访问
函数嵌套:一个函数内部可以调用另一个函数,但是不能在内部声明一个函数
链式访问:把一个函数的返回值作为另一个函数的参数
main()
{
int ret = strlen("hello");//这里介绍一下strlen函数,是求字符串长度
//printf("%d\n", ret);正常写法
printf(“%d\n”,strlen("hello"));//链式访问
return 0;
};
- 函数的递归
简单的说,递归就是自己调用自己。主要思考方式在于把大事化小
递归有两个必要条件(有这两个必要条件不一定对,但是没有一定错)
1.存在限制条件,当满足限制条件时,递归便不再继续 2.每次递归调用后越来越接近这个限制条件
例如输入1234打印出1 2 3 4
这是递归具体过程
void print( unsigned int n)//接受传递过来值n=123
{
if(n>9)
{
print(n/10);//12继续传递给自己
}
printf("%d ", n%10);//n=123%10=3,再继续打印,就完成了
}
void print( unsigned int n)//到这n=12
{
if(n>9)
{
print(n/10);//1再继续传递
}
printf("%d ", n%10);//n=12%10=2,再继续向上打印
}
void print( unsigned int n)//n=1进不去if判断,进行打印到printf语句
{
if(n>9)
{
print(n/10);
}
printf("%d ", n%10);//1%10=1在向上进行传递
}
//完整的函数代码
void print( unsigned int n)
{
if(n>9)
{
print(n/10);
}
printf("%d ", n%10);
}
main()
{
unsigned int num = 0;
scanf("%u", &num);//输入123传递给函数print,n=123
print(num);
return 0;
}