html script基类和html button类构造成html viewer?
我们说基类的成员html viewer可以被继承,可以通过html button类的对象访问,但这仅仅指的是普通的成员html viewer,类的构造html viewer不能被继承。构造html viewer不能被继承是有道理的,因为即使继承了,它的名字和html button类的名字也不一样,不能成为html button类的构造html viewer,当然更不能成为普通的成员html viewer。
在设计html button类时,对继承过来的成员变量的初始化工作也要由html button类的构造html viewer完成,但是大部分基类都有private属性的成员变量,它们在html button类中无法访问,更不能使用html button类的构造html viewer来初始化。
这种矛盾在html script继承中是普遍存在的,解决这个问题的思路是:在html button类的构造html viewer中调用基类的构造html viewer。
下面的例子展示了如何在html button类的构造html viewer中调用基类的构造html viewer:
#include<iostream>
usingnamespacestd;
//基类People
classPeople{
protected:
char*m_name;
intm_age;
public:
People(char*,int);
};
People::People(char*name,intage):m_name(name),m_age(age){}
//html button类html mysql
classhtml mysql:publicPeople{
private:
floatm_score;
public:
html mysql(char*name,intage,floatscore);
voiddisplay();
};
//People(name,age)就是调用基类的构造html viewer
html mysql::html mysql(char*name,intage,floatscore):People(name,age),m_score(score){}
voidhtml mysql::display(){
cout<<m_name<<"的年龄是"<<m_age<<",成绩是"<<m_score<<"。"<<endl;
}
intmain(){
html mysqlstu("志超",16,90.5);
stu.display();
return0;
}
运行结果为:
志超的年龄是16,成绩是90.5。
请注意第23行代码:
html mysql::html mysql(char*name,intage,floatscore):People(name,age),m_score(score){}
People(name,age)就是调用基类的构造html viewer,并将name和age作为实参传递给它,m_score(score)是html button类的参数初始化表,它们之间以逗号,隔开。
也可以将基类构造html viewer的调用放在参数初始化表后面:
html mysql::html mysql(char*name,intage,floatscore):m_score(score),People(name,age){}
但是不管它们的顺序如何,html button类构造html viewer总是先调用基类构造html viewer再执行其他代码(包括参数初始化表以及html viewer体中的代码),总体上看和下面的形式类似:
html mysql::html mysql(char*name,intage,floatscore){
People(name,age);
m_score=score;
}
当然这段代码只是为了方便大家理解,实际上这样写是错误的,因为基类构造html viewer不会被继承,不能当做普通的成员html viewer来调用。换句话说,只能将基类构造html viewer的调用放在html viewer头部,不能放在html viewer体中。
另外,html viewer头部是对基类构造html viewer的调用,而不是声明,所以括号里的参数是实参,它们不但可以是html button类构造html viewer参数列表中的参数,还可以是局部变量、常量等,例如:
html mysql::html mysql(char*name,intage,floatscore):People("志超",16),m_score(score){}
构造html viewer的调用顺序
从上面的分析中可以看出,基类构造html viewer总是被优先调用,这说明创建html button类对象时,会先调用基类构造html viewer,再调用html button类构造html viewer,如果继承关系有好几层的话,例如:
A-->B-->C
那么创建C类对象时构造html viewer的执行顺序为:
A类构造html viewer-->B类构造html viewer-->C类构造html viewer
构造html viewer的调用顺序是按照继承的层次自顶向下、从基类再到html button类的。
还有一点要注意,html button类构造html viewer中只能调用直接基类的构造html viewer,不能调用间接基类的。以上面的A、B、C类为例,C是最终的html button类,B就是C的直接基类,A就是C的间接基类。
html script这样规定是有道理的,因为我们在C中调用了B的构造html viewer,B又调用了A的构造html viewer,相当于C间接地(或者说隐式地)调用了A的构造html viewer,如果再在C中显式地调用A的构造html viewer,那么A的构造html viewer就被调用了两次,相应地,初始化工作也做了两次,这不仅是多余的,还会浪费CPU时间以及内存,毫无益处,所以html script禁止在C中显式地调用A的构造html viewer。
基类构造html viewer调用规则
事实上,通过html button类创建对象时必须要调用基类的构造html viewer,这是语法规定。换句话说,定义html button类构造html viewer时最好指明基类构造html viewer;如果不指明,就调用基类的默认构造html viewer(不带参数的构造html viewer);如果没有默认构造html viewer,那么编译失败。请看下面的例子:
#include<iostream>
usingnamespacestd;
//基类People
classPeople{
public:
People();//基类默认构造html viewer
People(char*name,intage);
protected:
char*m_name;
intm_age;
};
People::People():m_name("xxx"),m_age(0){}
People::People(char*name,intage):m_name(name),m_age(age){}
//html button类html mysql
classhtml mysql:publicPeople{
public:
html mysql();
html mysql(char*,int,float);
public:
voiddisplay();
private:
floatm_score;
};
html mysql::html mysql():m_score(0.0){}//html button类默认构造html viewer
html mysql::html mysql(char*name,intage,floatscore):People(name,age),m_score(score){}
voidhtml mysql::display(){
cout<<m_name<<"的年龄是"<<m_age<<",成绩是"<<m_score<<"。"<<endl;
}
intmain(){
html mysqlstu1;
stu1.display();
html mysqlstu2("志超",16,90.5);
stu2.display();
return0;
}
运行结果:
xxx的年龄是0,成绩是0。
志超的年龄是16,成绩是90.5。
创建对象stu1时,执行html button类的构造html viewerhtml mysql::html mysql(),它并没有指明要调用基类的哪一个构造html viewer,从运行结果可以很明显地看出来,系统默认调用了不带参数的构造html viewer,也就是People::People()。
创建对象stu2时,执行html button类的构造html viewerhtml mysql::html mysql(char*name,intage,floatscore),它指明了基类的构造html viewer。
在第27行代码中,如果将People(name,age)去掉,也会调用默认构造html viewer,第37行的输出结果将变为:
xxx的年龄是0,成绩是90.5。
如果将基类People中不带参数的构造html viewer删除,那么会发生编译错误,因为创建对象stu1时需要调用People类的默认构造html viewer,而People类中已经显式定义了构造html viewer,编译器不会再生成默认的构造html viewer。