6.1 分析以下程序的执行结果 #include<iostream.h> class base { public: base(){cout<<"constrUCting base class"<<endl;} ~base(){cout<<"destructing base class"<<endl; } }; class subs:public base { public: subs(){cout<<"constructing sub class"<<endl;} ~subs(){cout<<"destructing sub class"<<endl;} }; void main() { subs s; } 解: 本题说明单继续情况下构造函数和析构函数的调用顺序。这里base为基类,subs为派生类。 所以输出为: constructing base class constructing sub class destructing sub class destrcuting base class 注重:在单继续情况下,首先调用基类的构造函数 ,随后调用派生类的构造函数,析构函数的调用顺序则正好相反。
6.2 分析以下程序的执行结果: #include<iostream.h> class base { int n; public: base(int a) { cout<<"constructing base class"<<endl; n=a; cout<<"n="<<n<<endl; } ~base(){cout<<"destructing base class"<<endl;} }; class subs:public base { base bobj; int m; public: subs(int a,int b,int c):base(a),bobj(c) { cout<<"constructing sub cass"<<endl; m=b; cout<<"m="<<m<<endl; } ~subs(){cout<<"destructing sub class"<<endl;} }; void main() { subs s(1,2,3); } 解: 本题说明 派生类中含有对象成员情况下构造函数和析构函数的调用顺序。这里base为基类,subs为派生类,subs类的构造函数中含有对象成员。 所以输出为: constrcuting base class n=1 constructing base class n=3 constructing sub class m=2 destructing sub class destructing base class destructing base class 注重:当派生类中含有对象成员时,构造函数的调用顺序如下: 1)基类的构造函数 2)对象成员的构造函数 3)派生类的构造函数
析构函数的调用顺序与之相反
-------------------------------------------------
6.3 分析以下程序的执行结果 #include<iostream.h> class A { public: int n; }; class B:public A{}; class C:public A{}; class D:public B,public C { int getn(){return B::n;} }; void main() { D d; d.B::n=10; d.C::n=20; cout<<d.B::n<<","<<d.C::n<<endl; } 解: D类是从类和类派生的而类和类又都是从类派生的,但各有自己的副本。所以对于对象d,d.B::n与d.C::n是两个不同的数据成员它们互无联系。 所以输出为: 10,20 -------------------------------------------- 6.4 分析以下程序的执行结果 #include<iostream.h> class A { public: int n; }; class B:virtual public A{}; class C:virtual public A{}; class D:public B,public C { int getn(){return B::n;} }; void main() { D d; d.B::n=10; d.C::n=20; cout<<d.B::n<<","<<d.C::n<<endl; } 解: D类是从类和类派生的而类和类又都是从类派生,但这是虚继续关系即是虚基类因此和共用一个的副本所以对于对象d,d.B::n与d.C::n是一个成员。 所以输出为: 20,20 --------------------------------------- 6.5 假设图书馆的图书包含书名、编号作者属性读者饮包含姓名和借书证属性每位读者最多可借5本书,编写程序列出某读者的借书情况。 解: 设计一个类,从它派生出胃病书类book和读者类reader,在reader类中有一个rentbook()成员函数用于借阅图书。 程序代码如下: 本程序的执行结果如下: #include<iostream.h> #include<string.h> class object { char name[20]; int no; public: object(){} object(char na[],int n) { strcpy(name,na);no=n; } void show() { cout<<name<<"("<<no<<")"; } }; class book:public object { char author[10]; public: book(){} book(char na[],int n,char auth[]):object(na,n) { strcpy(author,auth); } void showbook() { show(); cout<<"作者:"<<author; } }; class reader:public object { book rent[5]; int top; public: reader(char na[],int n):object(na,n){top=0;} void rentbook(book &b) { rent[top]=b; top++; } void showreader() { cout<<"读者:";show(); cout<<endl<<"所借图书:"<<endl; for(int i=0;i<top;i++) { cout<<" "<<i+1<<":"; // 5个空格 rent[i].show(); cout<<endl; } } }; void main() { book b1("C语言",100,"谭浩强"),b2("数据结构",110,"严蔚敏"); reader r1("王华",1234); r1.rentbook(b1); r1.rentbook(b2); r1.showreader(); }
本程序的执行结果如下: 输出结果: 李明,年龄42岁,担任设计处处长, 高级工程师,从事电站锅炉设计专业。 三层交换技术 交换机与路由器密码恢复 交换机的选购 路由器设置专题 路由故障处理手册 数字化校园网解决方案 题 1. 分析以下程序的执行结果: #include<iostream.h> class base { int n; public: base(){}; base (int a) { cout << "constructing base class" << endl; n=a; cout << "n=" << n << endl; } ~base() { cout << "destructing base class" << endl; } }; class subs : public base { int m; public: subs(int a, int b) : base(a) { cout << "constructing sub class" << endl; m=b; cout << "m=" << m << endl; } subs() { cout << "destructing sub class" << endl; } }; void main () { subs s(1,2); }
解: 这里base 是基类,subs为派生类,subs类的构造函数中含有调用基本类的构造函数。 所以输出为: constructing base class n=1 constructing sub class n=2 destructing base class destructing sub class
题 3 分析以下程序的执行结果: #include <iostream.h> class A { int a; public: A(int i) { a=i;cout << "constructing class A" << endl; } void print() { cout << a << endl; } ~A() { cout << "destructing class A" << endl; } }; class Bi:public A { int bl; public: Bl(int i,int j):A(i) { bl=j;cout << "constructing class BI" << endl; void print() { A::print (); cout << bl << endl; } ~BI(){ cout << "destructing class BI" << endl; } }; class B2:public A { int b2; public: B2(int i,int j):A(i); { b2=j;cout << "constructing class B2" << endl; } void print() { A::print (); cout << b2 << endl; } ~B2() { cout << "destructing class B2" << endl; } }; class C:public B1,public B2 { int c; public: C(int i,int j,int k, int 1,int m) :Bl(i,j),B2(k,1),c(m) { cout << "constructing class C" << endl; } void print() { Bl::print(); B2::print(); cout << c << endl; } ~C( ){ cout << "destructing class C" << endl; } }; void main() { C c1(1,2,3,4,5); cl.print(); }
解: C类是从B1类和B2类派生的,而B1和B2类又都是从A类派生,但各有自己的副本,所有这些成员函数均有print()成员函数。所以,在C的成员函数实现中,调用print()时,要加上类作用域运算符“::”。 所以输出为: constructing class A constructing class B1 constructing class A constructing class B2 constructing class C 1 2 3 4 5 destructing class C destructing class B2 destructing class A destructing class B1 destructing class A