纯虚函数
纯虚函数是在声明虚函数时被“初始化”为0的函数:
一般形式:virtual 函数类型 函数名(参数列表)=0;
纯虚函数与抽象类
在定义一个表达抽象概念的基类时,有时可能会无法给出某些成员函数的具体实现。这时,就可以将这些函数声明为纯虚函数。
纯需函数的声明格式如下:
virtual 类型 函数名(参数表)=0;
声明了纯虚函数的基类只是用于继承,仅作为一个接口,具体功能在其派生类中实现。
声明了纯虚函数的类,称为抽象类。抽象类只能用作基类来派生新类,而不能用来创建对象。
纯虚函数没有函数体;最后的“ =0” 并不代表函数返回值为 0 ,它只起形式上的作用,告诉编译器“这是纯虚函数”;这个一个声明语句,最后有分号。
声明纯虚函数是告诉编译器,“在这里声明了一个虚函数,留待派生类中定义”。在派生类中对此函数提供了定义后,它才能具备函数的功能,可以被调用。
纯虚函数的作用是在基类中为其派生类保留了一个函数的名字,以便派生类根据需要对它进行定义。如果在一个类中声明了纯虚函数,而在其派生类中没有对该函数定义,则该函数在派生类中仍为纯虚函数。
函数参数
函数参数的求值顺序
当一个函数带有多个参数时,C++语言没有规定在函数调用时实参的求值顺序。而编译
器根据对代码进行优化的需要自行规定对实参的求值顺序。有的编译器规定自左至右,
有的编译器规定自右至左,这种对求值顺序的不同规定,对一般参数来讲没有影响。但
是,如果实参表达式中带有副作用的运算符时,就有可能产生由于求值顺序不同而造成
了二义性。例如:int z = add_int(++x, x+y);,这样,在不同的编译器就有可能生产
不同的结果。
设置参数的默认值
在C++语言中,允许在函数的说明或定义时给一个或多个参数指定默认值。但是,要求在
一个指定了默认值的参数的右边,不能出现没有指定默认值的参数。例如:
int add_int(int x, int 10);
在上述对函数add_int()的说明中,对该函数的最右边的一个参数指定了默认值。
在函数调用时,编译器按从左至右的顺序将实参与形参结合,当实参的数目不足时,编译
器将按同样的顺序用说明中或定义中的默认值来补足所缺少的实参。例如,如有下列的函
数调用表达式:
add_int(15)
它将与下列调用表达式:
add_int(15, 10)
是等价的。
在给某个参数指定默认值是,不仅可以是一个数值,而且还可以是任意复杂的表达式。
使用数组作函数参数
数组作函数参数可以分为如下三种情况:(这三种情况的结果相同,只是所采用的调用
机制不同)
1. 形参和实参都用数组
调用函数的实参用数组名,被调用函数的形参用数组,这种调用的机制是形参和实参共
用内存中的同一个数组。因此,在被调用函数中改变了数组中某个无素的值,对调用函
数该数组的该元素值也被改变,因为它们是共用同一个数组。
2. 形参和实参都用对应数组的指针
在C++中,数组名被规定为是一个指针,该指针便是指向该数组的首元素的指针,国为
它的值是该数组首元素的地址值,因此,数组名是一个常量指针。
实际中,形参和实参一个用指针,另一个用数组也是可以的。在使用指针时可以用数组
名,也可以用另外定义的指向数组的指针。
3. 实参用数组名形参用引用
如何对数组类型使用引用方式,这里先做如下说明:先用类型定义语句定义一个int型的
数组类型,如下所示:
typedef int array[8];
然后,使用array来定义数组和引用。
示例:
#include <iostream.h>
typedef int array[8];
int a[8] = {1, 3, 5, 7, 9, 11, 13};
void fun(array &b, int n)
{
for(int i=0; i<n-1; i++)
b[7]+=b[i];
}
void main()
{
int m=8;
fun(a, m);
cout<<a[7]<<endl;
}
该程序中,在fun()函数中,使用了引用作形参,调用时所对应的实参应该是一个数组
名,这里的引用是给数组起个别名。在fun()函数中对数组b的操作,就相当于b所引用
数组a的操作。在C++中,常用这种调用方式。