第12周-多继承、虚基类,继承和组合-课后实践·阅读程序

/* 
* Copyright (c) 2014, 烟台大学计算机学院 
* All rights reserved. 
* 文件名称:test.cpp 
* 作    者:刘畅 
* 完成日期:2015 年 5  月  24 日 
* 版 本 号:v1.0 
* 
* 问题描述:阅读程序~~
* 输入描述: ;
* 程序输出:。

(1)
#include <iostream>
using namespace std;
class A
{
public:
    A()
    {
        a=0;
    }
    A (int i)
    {
        a=i;
    }
    void print()
    {
        cout<<a<<"  ";
    }
private:
    int a;
};
class B: public A
{
public:
    B()
    {
        b=0;
    }
    B(int i, int j, int k): A(i),aa(j)
    {
        b=k;
    }
    void print()
    {
        A::print();
        aa.print();
        cout<<b<<endl;
    }
private:
    int b;
    A aa;
};
int main()
{
    B test[2];
    test[0]=B(1,4,7);
    test[1]=B(2,5,8);
    for(int i=0; i<2; i++)
        test[i].print();
    return 0;
}

运行结果:



(2)

#include <iostream>
using namespace std;
class A
{
public:
    A(string s)
    {
        cout<<s<<endl;
    }
};
class B:public A
{
public:
    B(string s1, string s2):A(s1)
    {
        cout<<s2<<endl;
    }
};
class C:public A
{
public:
    C(string s1,string s2):A(s1)
    {
        cout<<s2<<endl;
    }
};
class D:public B,C
{
public:
    D(string s1,string s2,string s3,string s4):B(s1,s2),C(s3,s4)
    {
        cout<<s4<<endl;
    }
};
int main()
{
    D d("class A","class B","class C","class D");
    return 0;
}

运行结果:


贺老给的阅读代码好像出了点问题,char 的没有输出,于是我给改成了string。。。看运行结果就能大致明白它的构造函数的执行顺序了。

(3)

#include <iostream>
using namespace std;
class Base
{
public:
    Base(char i) { cout<<"Base constructor. --"<<i<<endl; }
};
class Derived1:virtual public Base
{
public:
    Derived1(char i,char j):Base(i)
    {
        cout<<"Derived1 constructor. --"<<j<<endl;
    }
};
class Derived2:virtual public Base
{
public:
    Derived2(char i,char j):Base(i)
    {
        cout<<"Derived2 constructor. --"<<j<<endl;
    }
};
class MyDerived:public Derived1,public Derived2
{
public:
    MyDerived(char i,char j,char k,char l,char m,char n,char x): Derived2(i,j), Derived1(k,l), Base(m), d(n)
    {
        cout<<"MyDerived constructor. --"<<x<<endl;
    }
private:
    Base d;
};
int main()
{
    MyDerived obj('A','B','C','D','E','F','G');
    return 0;
}

运行结果:


这个还存有疑问。

(4)

#include<iostream>
using namespace std;
class A
{
public:
    int n;
};
class B:public A {};   // class B:virtual public A{};
class C:public A {};   // class C:virtual public A{};
class D:public B,public C
{
public:
    int getn()
    {
        return B::n;
    }
};
int main()
{
    D d;
    d.B::n=10;
    d.C::n=20;
    cout<<d.getn()<<endl;
    return 0;
}

运行结果:


#include<iostream>
using namespace std;
class A
{
public:
    int n;
};
class B:virtual public A{};
class C:virtual public A{};
class D:public B,public C
{
public:
    int getn()
    {
        return B::n;
    }
};
int main()
{
    D d;
    d.B::n=10;
    d.C::n=20;
    cout<<d.getn()<<endl;
    return 0;
}

修改后运行结果:



(5)

#include <iostream>
using namespace std;
class A
{
protected:
    int a,b;
public:
    A(int aa, int bb):a(aa), b(bb) {}
    void printA()
    {
        cout<<"a: "<<a<<"\tb: "<<b<<endl;
    }
};
class B: public A
{
    int c;
public:
    B(int aa, int bb, int cc):A(aa,bb),c(cc) {}
    void printB()
    {
        cout<<"a: "<<a<<"\tb: "<<b<<"\tc: "<<c<<endl;
    }
};
int main()
{
    A a(1,1);
    B b(2,3,4);
    //此处加入下面各小题中的代码
    return 0;
}

(a)
    a=b;
    a.printA();
    b.printA();
    b.printB();
运行结果:


(b)

b=a;  
a.printA();  
b.printA();  
b.printB();
运行结果:



可以通过派生类对象向基类赋值,但反过来是行不通的


(c)

    A &r1=a;
    A &r2=b;
    r1.printA();
    r2.printA();
    r2.printB();
运行结果:

不能通过派生类对象去访问基类对象的成员,

删除后:



(d)

    A *p=&a;
    p->printA();
    p=&b;
    p->printA();
    p->printB();

运行结果:


指向基类的指针只能访问派生类中的基类成员,而不能访问派生类中增加的成员。

删除后:



(e)

在classA中增加成员函数:

    int getA(){return a;}

在main函数前增加一段函数:

void f(A x)
{
    cout<<"aaaaah, my a: "<<x.getA()<<endl;
}

main函数中指定部分为:

    f(a);
    f(b);

代码如下:

#include <iostream>
using namespace std;
class A
{
protected:
    int a,b;
public:
    A(int aa, int bb):a(aa), b(bb) {}
    void printA()
    {
        cout<<"a: "<<a<<"\tb: "<<b<<endl;
    }
    int getA()
    {
        return a;
    }
};
class B: public A
{
    int c;
public:
    B(int aa, int bb, int cc):A(aa,bb),c(cc) {}
    void printB()
    {
        cout<<"a: "<<a<<"\tb: "<<b<<"\tc: "<<c<<endl;
    }
};
void f(A x)
{
    cout<<"aaaaah, my a: "<<x.getA()<<endl;
}

int main()
{
    A a(1,1);
    B b(2,3,4);
    f(a);
    f(b);
    return 0;
}

运行结果:




(6)补充阅读:

#include <iostream>
using namespace std;
class B
{
public:
    B(int x=0)
    {
        X=x;
        cout<<"B("<<x<<")\n";
    }
    ~B()
    {
        cout<<"~B()\n";
    }
    void print()
    {
        cout <<X<< " ";
    }
private:
    int X;
};


class D: public B
{
public:
    D (int x, int y):B(x)
    {
        Y=y;
        cout<<"D("<<x<<","<<y<<")\n";
    }
    ~D()
    {
        cout<<"~D()\n";
    }
    void print()   //与基类中的成员函数同名!这个冲突如何解决的?!
    {
        B::print();
        cout <<Y<<endl;
    }
private:
    int Y;
};
int  main()
{
    D d(11,22);
    d.print();
    return 0;
}

是通过作用域限定符解决了基类和派生类成员函数同名的问题。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值