目录
一、函数的概念
二、库函数
三、自定义函数
四、形参与实参
五、return语句
六、数组作为函数参数
七、函数的声明和定义
//该篇文章使用的部分素材和内容来自比特就业课
一、函数的概念
在C语言中函数就是完成某项特定任务的一小段代码,也被称为子程序。它们有着特殊的写法和调用方法。
一个C语言程序就是由多个函数构成的。这些函数将复杂的大型任务分解为多个简单的模块来执行。这些能够执行特定任务的函数可以被反复多次地使用,由此提高了软件开发效率。
在C语言中,常见到如下两种函数:
1. 库函数
2. 自定义函数
二、库函数
1. 标准库与头文件
C语言的国际标准(ANSI C)规定了一些常用的函数标准。不同的编译器厂商为了实现给出的标准,创建了一系列函数,它们就被称为库函数。
我们常用的库函数如:printf、scanf等都是库函数。库函数都是现成的,我们只需学会如何使用即可,这大大提高了我们的编码效率,也保障了函数质量与执行效率。
在使用库函数之前,我们需要通过头文件来作为声明,告知我们将要调用哪些库函数。常见的头文件有:stdio.h等。
2. 库函数的使用方法
举例:pow
功能
pow函数用于计算x的y次幂。
头文件
math.h
实现:
三、自定义函数
在编码过程中,库函数往往无法满足我们的所有需求。这时,我们便可以依据自身的需要来自定义一个函数,来实现我们所需要的功能。
1. 语法形式
ret_type: 表示函数返回类型
fun_name:表示函数名
()内为形式参数
{}内为函数体
举例:
在本图中:
int :为自定义函数Add的返回类型,这是因为该函数返回的是(x+y)的值,而x为整型,y也为整型,所以它们的和(返回值)也为整型,因此该函数的返回类型为整型(int)
Add:为自定义函数的函数名
(int x,int y):x和y为该函数的形式参数
return (x + y):(x + y)为该函数的返回值
四、形参与实参
在函数使用中,我们将参数分为两类:形参与实参
以上图代码为例:
1. 实参
在上图中,代码2 ~5行为函数Add的定义,代码11行为Add函数的调用。在调用函数时,我们将a、b作为参数传给函数,它们(a和b)即为实际参数,简称实参。
实参就是真实传递给函数,用于处理的参数。
2. 形参
在代码第2行的int x和int y即为形式参数,简称形参。形参反应了该函数所接受的实参的数量和类型。在没有实参传递时(即函数未被调用时),形参不会向内存申请空间,而只是在形式上存在;当有实参传递(函数被调用)时,为了存放实参传递来的值,形参才会向内存申请空间,这个过程就是形参的实例化。
3. 形参与实参的关系
形参虽然接受了实参的传递,但这并不意味着他们在内存中占据着同样的空间。形参可以看作实参的复制备份,它们在内存中占据着不同的空间。
五、return语句
在C语言中,return语句有以下几种常见用法。
1.return后边可以是一个数值,也可以是一个表达式,如果是表达式则先执行表达式,再返回表达式的结果。
2.return后边也可以什么都没有,直接写return;这种写法适合函数返回类型是void的情况。
3.return返回的值和函数返回类型不一致,系统会自动将返回的值隐式转换为函数的返回类型。
4.return语句执行后,函数就彻底返回,后边的代码不再执行。
5.如果函数中存在if等分支的语句,则要保证每种情况下都有return返回,否则会出现编译错误。
六、数组做函数参数
在调用函数时,我们可能需要将数组传递给函数来进行处理。
举个例子:
以下代码能够实现将整型数组内的内容以降序排列。
在上图中,为了使用order函数的功能,我们需要将数组和数组的元素个数都传递过去。
当我们进行数组传参时,需注意以下几点:
1.函数的形式参数要和函数的实参个数匹配
2.函数的实参是数组,形参也是可以写成数组形式的形参如果是一维数组,数组大小可以省略不写
3.形参如果是二维数组,行可以省略,但是列不能省略
4.数组传参,形参是不会创建新的数组的
5.形参操作的数组和实参的数组是同一一个数组
❗️注意:在进行数组传参时,函数的实参为数组名!
七、函数的声明和定义
以之前的代码为例:
上图中蓝色的部分是函数的定义,而order(arr,sz )则是函数的调用。
在上图的情况下,程序可以正常运行。
但当我们将函数的定义放在函数调用之后,如下图所示:
在该程序中,order函数被识别为未定义的函数,这是因为编译器在进行编译时,是从上到下逐条编译的,所以当程序在main函数中编译到order函数时会将其视为未定义的函数。
为了解决这个问题,我们要事先进行函数的声明。
如下图所示:
通过对函数进行声明,我们就可以将自定义函数置于main函数之后使用。
❗️ 注意:函数的调用一定要满足:先声明后使用
函数的定义也是一种特殊的声明,所以如果函数的定义放在调用之前也是可以的。