面向对象编程(C++) 实验 - 追着光梦游

面向对象编程(C++) 实验

c/c++实验代码 2017-06-15

实验一

目的与要求
问题描述:分别定义Teacher(教师)类和Cadre(干部)类,采用多重继承方式由这两个类派生出新类Teacher_Cadre(教师兼干部)。要求:
(1)在两个基类中都包含姓名、年龄、性别、地址、电话等数据成员。
(2)在Teacher类中还包含数据成员title(职称),在Cadre类中还包含数据成员post(职务),在Teacher_Cadre类中还包含数据成员wages(工资)。
(3)对两个基类中的姓名、年龄、性别、地址、电话等数据成员用相同的名字,在引用这些数据成员时,指定作用域。
(4)在类体中声明成员函数,在类外定义成员函数。
(5)在派生类Teacher_Cadre的成员函数show中调用Teacher类中的display函数,输出姓名、年龄、性别、职称、地址、电话,然后再用cout语句输出职务与工资

***操作环境*** 硬件: Hp PC 软件:dev c++ ***实验内容*** 实验包括了两个文件,分别是一个cpp源文件个一个.h头文件,源文件中是main函数,头文件中是各种类及函数的定义和声明。其中: **.h文件中包含:** Teacher,Cadre,Teacher_Cadre三个类; 每个类的构造函数和display和show函数。 Teacher类和Cadre作为基类,都包含了姓名、年龄、性别、地址、电话等数据成员,在Teacher类中还包含数据成员title(职称),在Cadre类中还包含数据成员post(职务)。 Teacher_Cadre类作为派生类,从Teacher类和Cadre类派生而来,实现了多重继承。 基类的构造函数负责对自己类中数据成员的初始化,多重继承派生类Teacher_Cadre的构造函数负责对两个基类以及新增的的数据成员进行初始化。display函数负责输出基类Teacher和Cadre中的数据成员show函数中调用了Teacher类中的display函数,并用cout语句进行输出,输出了所有数据成员。如下是1.h头文件
#include<iostream>
#include<string>
using namespace std;
class Teacher/*teacher类*/
{
public:
 void display();
 Teacher(string nam,int a,char s,string ad,string te,string tit);
protected:
 string name;
 int age;
 char sex;
 string address;
 string tel;
 string title;
};
class Cadre/*cadre类*/
{
public:
 void display();
 Cadre(string nam,int a,char s,string ad,string te,string p);
protected:
 string name;
 int age;
 char sex;
 string address;
 string tel;
 string post;
};
class Teacher_Cadre:public Teacher,public Cadre/*多重继承派生类*/
{
public:
 Teacher_Cadre(string nam,int a,char s,string ad,string te,string tit,string p,int w):
   Teacher(nam,a,s,ad,te,tit),Cadre(nam,a,s,ad,te,p),wage(w) {}//先声明先调用构造函数
   void show();
protected:
 int wage;
};
//定义构造函数
Teacher::Teacher(string nam,int a,char s,string ad,string te,string tit)
{
 name=nam;
 age=a;
 sex=s;
 address=ad;
 tel=te;
 title=tit;
}
Cadre::Cadre(string nam,int a,char s,string ad,string te,string p)
{
 name=nam;
 age=a;
 sex=s;
 address=ad;
 tel=te;
 post=p;
}
//定义display与show函数
void Teacher::display()
{
 cout<<"name:"<<name<<endl;
 cout<<"age:"<<age<<endl;
 cout<<"sex:"<<sex<<endl;
 cout<<"address:"<<address<<endl;
 cout<<"tel:"<<tel<<endl;
 cout<<"title:"<<title<<endl;
}
void Cadre::display()
{
 cout<<"name"<<name<<endl;
 cout<<"age"<<age<<endl;
 cout<<"sex"<<sex<<endl;
 cout<<"address"<<address<<endl;
 cout<<"tel"<<tel<<endl;
 cout<<"post"<<post<<endl;
}
void Teacher_Cadre::show()
{
 Teacher::display();//调用Teacher类中的display函数
 cout<<"post:"<<post<<endl;//用cout语句输出职务与工资
 cout<<"wage:"<<wage<<endl;
 cout<<"\n"<<endl;
}

.cpp中包含:
main函数,它分别定义了三个Teacher_Cadre类对象t1.t2.t3,并赋予实参,并调用show函数,进行输出。如下是.cpp文件

 #include"1.h"

int main ()

{
 Teacher_Cadre t1("liguopeng",19,'m',"14605","13278887766","middle","boss",16000);
 t1.show();
  Teacher_Cadre t2("mxx",18,'m',"14605","13273332166","middle","boss",20000);
 t2.show();
  Teacher_Cadre t3("hwc",19,'m',"14605","13254152166","high","boss",20000);
 t3.show();
 return 0;
}

实验总结
1)继承与派生时,会发生覆盖的问题,派生类覆盖基类。
2)多重继承派生时的构造函数与单继承时的构造函数形式基本相同,只是在初始表中包含多个基类构造函数。

实验二

目的与要求
问题描述:在实验一的基础上,定义抽象基类并定义一个链表遍历各个节点,输出Teacher_cadre类内的数据。
操作环境
硬件: Hp PC
软件:dev c++
实验内容
实验包括了两个文件,分别是一个cpp源文件个一个1.1.h头文件,源文件中是main函数,头文件中是各种类及函数的定义和声明。其中:
1.1.h中包含:
person,Teacher,Cadre,Teacher_Cadre四个类; 每个类的构造函数,person类的虚析构函数和两个纯虚函数即display和show函数。Person类作为祖先类包含了姓名、年龄、性别、地址、电话等数据成员,Teacher类和Cadre作为子类,用了虚继承的方式,利用virtual关键字由person类派生而来,在Teacher类中还包含数据成员title(职称),在Cadre类中还包含数据成员post(职务)。
Teacher_Cadre类为孙子类,从Teacher类和Cadre类多重派生而来。
person类的构造函数负责对自己类中数据成员初始化,利用虚继承而派生来的Teacher类和Cadre类的构造函数负责对直接基类person类和新增的数据成员进行初始化。孙子类Teacher_Cadre的构造函数负责对三个基类的新增的数据成员进行初始化。display函数负责输出基类Teacher和Cadre中的数据成员。孙子类中的show函数中调用了Teacher类中的display函数,并用cout语句进行输出,输出了所有数据成员。

#include<iostream>
#include<string>
using namespace std;
class person//定义祖先类 
{
public:
    person(string,int,char,string,string);
    virtual~person()//虚析构函数 
    {
        cout<<"object deleted\n";
     } 
    virtual void display() =0;//纯虚函数 
    virtual void show() =0;//纯虚函数 
    person *next ;//链表 
protected:
    string name;
    int age;
    char sex;
    string addr;
    string tel;
};
person::person(string nam,int a,char s,string ad,string t) 
{name=nam; age=a; sex=s; addr=ad; tel=t;}

class Teacher:virtual public person//虚继承 
{
public:
    Teacher(string,int,char,string,string,string);
    void display();
protected:

    string title;
};
Teacher::Teacher(string nam,int a,char s,string ad,string t,string ti):person(nam,a,s,ad,t)
{title=ti; }
void Teacher::display ()
{   cout<<"name: "<<name<<"\nage: "<<age<<"\nsex: "<<sex<<"\naddress: "<<addr<<"\ntel: "<<tel<<"\ntitle: "<<title<<endl;  }

class Cadre:virtual public person//虚继承 
{
public:
    Cadre(string,int,char,string,string,string);
protected:

    string post;
};
Cadre::Cadre(string nam,int a,char s,string ad,string t,string p):person(nam,a,s,ad,t)
{   post=p; }

class Teacher_cadre:public Teacher,public Cadre 
{
public:
    Teacher_cadre(string,int,char,string,string,string,string,int);
    void show();
private:
    int wages;
};
Teacher_cadre::Teacher_cadre(string nam,int a,char s,string ad,string t,string ti,string p,int w):person(nam,a,s,ad,t),
Teacher(nam,a,s,ad,t,ti),Cadre(nam,a,s,ad,t,p),wages(w){}
void Teacher_cadre::show()
{
    Teacher::display ();
    cout<<"post: "<<Cadre::post <<"\nwages: "<<wages<<endl;
}

.cpp中包含:
main函数和链表,利用链表循环遍历三个类对象,利用show函数输出了数据成员。利用new开辟存储空间,并用delete释放,调用了虚析构函数,输出了三个“object deleted”

#include"1.1.h" 
int main()
{
    //生成链表 
    person *head,*p;
    head=new Teacher_cadre("zhao",25,'m',"beijing","10086","a","stuff",5000);
    p=head;
    p->next=new Teacher_cadre ("qian",27,'f',"shanghai","95580","b","ziyouzhiye",6000);
    p=p->next;
    p->next=new Teacher_cadre ("sun",30,'m',"shenzhen","100109","c","boss",9000);
    p=p->next;
    p->next=NULL;
    //循环链表输出 
    p=head;
    while(p!=NULL)
    {
        p->show();
        p=p->next;
        cout<<"\n";
    }
    //删除new的空间
    p=head;
    while(head!=NULL)
    {
        head=p->next;
        delete p;
        p=head; 
    }
    getchar(); 
    return 0;
}

实验总结
1)包含有有纯虚函数的类即是抽象类,抽象类不能定义对象,纯虚函数的作用是在基类中为其派生类保留一个函数的名字,以便派生类根据需要对它进行定义。利用(纯)虚函数可以实现多态性。
2)关于多重继承引起的二义性问题,可以利用虚基类来解决。
3)未使用虚继承时,在派生类的构造函数中只须负责对其直接基类初始化,再由其直接基类负责对间接基类初始化,现在,使用了虚继承,在最后的派生类中不仅要负责对其直接基类进行还要负责对虚基类初始化。
4)本实验利用了纯虚函数,虚继承,多重继承,链表等知识,自己对于这些知识的掌握还不是很扎实,尤其是链表,自己需要多多加强。


本文由 guopengli 创作,采用 知识共享署名 3.0,可自由转载、引用,但需署名作者且注明文章出处。
  • 浏览次数: 590
  • 还不快抢沙发

    添加新评论