一.inline函数
当程序执行函数调用时,系统要建立栈空间,保护现场,传递参数以及控制程序执行的转移等等,这些工作需要系统时间和空间的开销。
当函数功能简单,使用频率很高,为了提高效率,直接将函数的代码镶嵌到程序中。但这个方法有缺点,一是相同代码重复书写,二是程序的可读性往往没有函数好。
为了协调 好效率和可读性之间的矛盾,C++提供了另一种方法,即定义内联函数,方法是在定义函数时用修饰词inline。
加inline关键字将其改成内联函数,在编译期间编译器能够在调用点内联展开该函数。
要点:
inline是一种以空间换时间的做法,省去调用函数额开销。但当函数体的代码过长或者递归函数。即便加上inline关键字,也不会在调用点以内联展开该函数。
inline对于编译器而言只是一个建议,编译器会自动优化。
inline不建议声明和定义分离,分离会导致链接错误。因为inline被展开,没有函数地址了,链接就会找不到。
内联函数与宏定义的区别:
1.内联函数在编译时展开,带参的宏在预编译时展开。
2.内联函数直接嵌入目标代码中,带参的只是做简单的目标替换。
3.内联函数有类型检测,有语法判断等功能,宏只是替换。
二.缺省参数
缺省参数在定义函数时为形参指定的缺省值(默认值)。
一般情况下,函数调用时的实参个数与形参相同,但为了更方便地 使用函数,C++也允许定义具有缺省参数的函数,这种函数调用时,实参个数可以与形参不相同。
这样的函数在调用时,对于缺省参数,可以给出实参值,也可以不给出参数值。如果给出实参,将实参传递给形参进行调用,如果不给出实参,则按缺省值进行调用。
缺省参数的函数调用:缺省实参并不一定是常量表达式,可以是任意表达式,甚至可以通过函数调用给出。如果缺省实参是任意表达式,则函数每次被调用时该表达式被重新求值。但表达式必须有意义。
缺省参数可以有多个,但所有的缺省参数必须放在参数表右侧,即先定义所有的非缺省参数,再定义缺省参数。这是因为在函数调用时,参数自左向右逐个匹配,当实参和形参个数不一致时只有这样才不会产生二义性。
void fun(int a,int b=23,int c=8000)
{
cout<<"a ="<<a<<" b =" << b <<"c="<<c<<endl;
}
int main()
{
fun(12);
fun(10,20);
fun(10,20,30);
fun(10,,30);//error
return 0;
}
习惯上,缺省参数在公共头文件包含的函数定义声明中指定,不要函数的定义中指定。
如果在函数的定义中指定缺省参数值,在公共头文件包含的函数声明中不能再指定缺省参数值。
缺省参数不一定必须是常量表达式,可以用任意 表达式。
当缺省实参是一个表达式时,在函数被调用时该表达式被求值。
#include<iostream>
using namespace std;
int my_rand()
{
srand(time(NULL));
int ra=rand()%100;
return ra;
}
void fun(int a,int b=my_rand())
{
cout<<"a="<<a<<"b="<<b<<endl;
}
int main()
{
fun(12);
return 0;
}
标签:函数,int,缺省,C++,参数,inline,实参
From: https://blog.csdn.net/2302_80090192/article/details/140432094