目录
一、概述
作用:
- 将一段经常使用的代码封装起来,减少重复代码
- 一个较大的程序,一般分为若干个程序块,每个模块实现特定的功能
二、函数的定义
- 返回值类型
- 函数名
- 参数列表
- 函数体语句
- return表达式
返回值类型 函数名 (参数列表)
{
函数体语句
return表达式
}
三、函数的调用
函数名 (参数)
注意:
- 函数定义的时候,参数为形参
- 调用时的参数为实参
四、值传递
- 值传递:单项传递,函数调用时实参将数值传入给形参
- 值传递时,如果形参发生改变,并不会影响实参
五、函数的常见样式
- 无参无返
- 有参无返
- 无参有返
- 有参有返
#include<iostream>
using namespace std;
//函数常见样式
//无参无返
void test01()
{
cout<<"This is test01"<<endl;
}
//有参无返
void test02(int a)
{
cout<<"This is test02 a="<<a<<endl;
}
//无参有返
int test03()
{
cout<<"This is test03"<<endl;
return 1000;
}
//有参有返
int test04(int b)
{
cout<<"This is test04"<<endl;
return b;
}
/*结果:
This is test01
This is test02 a=100
This is test03
num1=1000
This is test04
num2=200
*/
int main(){
//无参无返调用
test01();
//有参无返调用
test02(100);
//无参有返调用
int num1=test03();
cout<<"num1="<<num1<<endl;
//有参有返调用
int num2=test04(200);
cout<<"num2="<<num2<<endl;
return 0;
}
六、函数的声明
作用:
- 告诉编译器函数名称及如何调用函数,函数的实际主体可以单独定义
注意:
- 函数的声明可以多次,但是函数的定义只能有一次
七、函数的分文件编写
步骤:
- 创建后缀名为.h的头文件
- 创建后缀名为.cpp的源文件
- 在头文件中写函数的声明
- 在源文件中写函数的定义
案例-嵌套调用
编程求解表达式f(k,n)=1^k + 2^k + … + n^k.
#include<iostream>
using namespace std;
//编程求解表达式f(k,n)=1^k + 2^k + … + n^k.
//n,k从键盘输入
//m^k
int pow(int m,int k)
{
int p=1;
for(int i=1;i<=k;i++)
p=p*m;
return p;
}
//累加
int sum(int n,int k)
{
int s=0;
for(int i=1;i<=n;i++)
s+=pow(i,k);
return s;
}
int main(){
int n,k;
cout<<"请输入n和k的值:"<<endl;
cin>>n>>k;
cout<<"1^"<<k<<" + 2^"<<k<<" + … + "<<n<<"^"<<k<<"="<<sum(n,k)<<endl;
return 0;
}
案例-递归调用
计算n!
#include<iostream>
using namespace std;
//计算n!
/*可用公式表示为
fact(n)=
{
1 n=0/1
n*fact(n-1) n>1
}
*/
float fact(int n)
{
float p;
if(n==0||n==1)
p=1;
else
p=n*float(n-1);
return p;
}
int main(){
int n;
cout<<"请输入n的值:"<<endl;
cin>>n;
cout<<"n!="<<fact(n)<<endl;
return 0;
}
八、内联函数
对于函数体比较短小,功能比较简单的函数,在调用时系统执行函数体所消耗的时间与函数调用时的其他时间开销相比显得微不足道。若这种函数被频繁调用,附加的时间开销将大的不容忽视。
为解决这一矛盾,提供“内联函数”的机制。
该机制将函数体代码直接插入到函数调用处,将调用函数的方式改为顺序执行插入的程序代码,以此来节省调用函数的时间开销。
定义一个内联函数,只需在定义函数时在函数的类型前增加关键字inline修饰即可。
案例-用内联函数实现求两个整型数中的大数的函数
#include<iostream>
using namespace std;
//用内联函数实现求两个整型数中的大数的函数
inline int max(int a,int b)
{
return(a>b?a:b);
}
int main()
{
int x,y;
cout<<"请输入两个数:"<<endl;
cin>>x>>y;
cout<<"两数中的大数为:"<<max(x,y)<<endl;
return 0;
}