- 1、本文档共48页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
例如: inline int mul(int a,int b) { return a*b; } 当程序中出现mul(2+3,4)的函数调用时,编译程序就会将其扩展为(2+3)*4。关键字inline是一个编译命令,编译程序在遇到这个命令时将记录下来,在处理内联函数的调用时,编译程序就试图产生扩展码。这样从使用者的角度来看,内联函数在语法上与一般函数没有什么区别,只是在编译程序生成目标代码时才区别处理。 一般情况下,我们对内联函数做如下的限制: (1) 不能有递归 (2) 不能包含静态数据 (3) 不能包含循环 (4) 不能包含switch和goto语句 (5) 不能包含数组 若一个内联函数定义不满足以上限制,则编译系统把它当作普通函数对待。 带缺省参数的函数 如果在函数说明或函数定义中为形参指定一个缺省值,则称此函数为带缺省参数的函数。当函数调用发生后,在形参表中等号后的各“缺省值”将起实参的传递作用。 如果在函数原型的声明中设置了函数参数的缺省值,则不可再在函数定义的头部重复设置,否则编译时将出现错误信息。 指定默认参数值可以使函数的使用更为简单,同时也增强了函数的可重用性。 注意: 默认形参值必须按从右向左的顺序定义。在有默认值的形参右面,不能出现无默认值的形参。因为在调用时,实参初始化形参是按从左向右的顺序。例如: void try(int j=3,int k) //非法 void try(int j,int k=2,int m) //非法 void try(int j,int k=7) //合法 void try(int j,int k=2,int m=3) //合法 void try(int j=3,int k=2,int m=3) //合法 默认形参值应该在函数原型中给出。例如: int multi(int x=2,int y=5); //默认形参值在函数原型中给出 void main( ) { multi( ); //并非无参调用,而是采用默认值,x取值2,y取值5 } int multi(int x,int y) { return(x*y); } 在相同的作用域内,默认形参值的说明应保持唯一。但如果在不同的作用域内,允许说明不同的默认形参。这里的作用域是指直接包含着函数原型说明的大括号所界定的范围。例如: int add(int x=2,int y=5); //全局默认形参值 void main( ) { int add(int x=1,int y=9); //局部默认形参值 add( ); //此处调用时,采用局部默认形参值,x取值1,y取值9 } void func(void) { add( ) //此处调用时,采用全局默认形参值,x取值2,y取值5 } C++允许为两个或两个以上的函数取相同的函数名,但是形参的个数或者形参的类型不应相同,编译系统会根据实参和形参的类型及个数的最佳匹配,自动确定调用哪一个函数,这就是所谓的函数重载。 函数重载无需特别声明,只要所定义的函数与已经定义的同名函数形参形式不完全相同,C++编译器就认为是函数的重载。 函数重载 对于没有重载机制的C语言,每个函数必须有其不同于其它函数的名称,即使操作是相同的,仅仅数据的类型不相同,也需要定义名称完全不同的函数,这样就显得重复且效率低下。例如,定义求平方函数,就必须对整数的平方、浮点数的平方以及双精度数的平方分别用不同的函数名: intisq(int x,int y); float fsq(float x,float y); double dsq(double x,double y); 程序在调用这三个不同类型的函数时,是以名字加以区别的,需要记住并区别它们的名称。显然,这样就造成了代码的重复,使用起来也不方便,更不利于代码的维护。 对于具有重载机制的C++语言,允许功能相近的函数在相同的作用域内以相同函数名定义,因而使函数方便使用,便于记忆,也使程序设计更加灵活。仍以上例而言,在C++中只要用一个函数名即可,如square( ),然后以赋给此函数的参数类型来决定是要计算int型、float型,还是double型的数的平方。 上例在C++中的定义形式如下:
文档评论(0)