WangDing
C++面向对象程序设计基础实验报告
C++面向对象程序设计基础实验报告 ............................................................................ 1 1 面向对象的程序设计 ................................................................................................ 3
1.1 基本概念 ........................................................................................................... 3
1.1.1 类的特征 ................................................................................................. 3 1.1.2 基类 ......................................................................................................... 3 1.1.3 子类 ......................................................................................................... 3
2 C++语言基础 ............................................................................................................. 3
2.1 C++优势 ............................................................................................................ 3 2.2 头文件变化 ....................................................................................................... 3 2.3 输入输出变化 ................................................................................................... 4 2.4 数据类型 ........................................................................................................... 4 2.5 表达式 ............................................................................................................... 4 2.6 语句 ................................................................................................................... 4 3 类和对象 .................................................................................................................... 4
3.1 类 ....................................................................................................................... 4 3.2 构造函数和析构函数 ....................................................................................... 5 3.3 对象数组与对象指针 ....................................................................................... 5 4 静态成员与友元 ........................................................................................................ 5
4.1 静态成员 ........................................................................................................... 5 4.2 友元 ................................................................................................................... 5 5 派生类与继承 ............................................................................................................ 5
5.1 继承 ................................................................................................................... 5 5.2 派生类 ............................................................................................................... 5 5.3 继承的两种方式 ............................................................................................... 6 6 多态性 ........................................................................................................................ 6
6.1 多态 ................................................................................................................... 6 6.2 函数重载 ........................................................................................................... 6 6.3 运算符重载 ....................................................................................................... 6 6.4 三大原则 ........................................................................................................... 6 6.5 模板 ................................................................................................................... 6
6.5.1 模板 ......................................................................................................... 6 6.5.2 函数模板 ................................................................................................. 7 6.5.3 类模板 ..................................................................................................... 7
7 虚函数 ........................................................................................................................ 7
1 / 32
Email:572645517@qq.com
Monday, June 24, 2019
8
WangDing
9
实验内容 .................................................................................................................... 7 8.1 输入3个整数,按由小到大的顺序输出 ....................................................... 7 8.2 输入3个字符串,按由小到大的顺序输出 ................................................... 8 8.3 写一函数,将一个3X3的矩阵转置 ............................................................ 10 8.4 两个字符串的比较 ......................................................................................... 11 8.5 输出100以内的所有素数 ............................................................................. 13 8.6 实现10个整数的冒泡排序 ........................................................................... 14 8.7 求三个数的最大公约数与最小公倍数 ......................................................... 15 8.8 用递归的方法求n!......................................................................................... 17 8.9 n个人围成一圈,顺序排号 .......................................................................... 18 8.10 给链表结点赋值 ............................................................................................ 20 8.11 n个整数位置移动 .......................................................................................... 22 8.12 计算矩形的周长和面积 ................................................................................ 23 8.13 学校在册人员类 ............................................................................................ 25 8.14 构造一个日期时间类 .................................................................................... 27 8.15 设计一个汽车类 ............................................................................................ 29 心得体会 .................................................................................................................. 31
2 / 32
Email:572645517@qq.com
Monday, June 24, 2019
WangDing
1 面向对象的程序设计
1.1 基本概念
面向对象的程序设计是通过对类、子类和对象等的设计来体现的,类是面向对象程序设计技术的核心。
类:定义了对象特征以及对象外观和行为的模板。
1.1.1 类的特征
(1). 封装性:隐藏了类中对象的内部数据或操作细节,只看到外表信息。
(2). 继承性:任何类都可以从其它已有的类中派生,新类保持了父类中的行为和属性,但增加了新的功能。体现了面向对象设计方法的共享机制。
(3). 多态性:相同的操作可作用于多种类型的对象上,并获得不同的结果。
(4). 抽象性:提取一个类或对象与众不同的特征,而不对该类或对象的所有信息进行处理。
1.1.2 基类
系统本身提供的类称为基类。基类包括容器类和控件类。容器类是其他对象的集合,如表格、选项按钮组;控件类是单一的对象,不包含其他对象,如命令按钮、文本框。
1.1.3 子类
以其他类定义为起点,对某一对象所建立的新类。新类将继承任何对父类所做的修改。
2 C++语言基础
2.1 C++优势
C++既可以用于面向过程的结构化程序设计,也可用于面向对象的程序设计。 C++对C的增强体现在两个方面: (1). 对原来的面向过程机制做了扩充。 (2). 增加了面向对象的机制。
学习C++之后,既可以进行面向对象的程序设计,也可以进行面向过程的程序设计。
2.2 头文件变化
为了与C兼容, C++保留了C语言中的一些规定,例如头文件的文件名,以C语
3 / 32
Email:572645517@qq.com
Monday, June 24, 2019
WangDing
言里头文件的扩展名是 .h,许多C++编译系统保留了这种扩展名,近年推出的C++编译系统新版本,推出了一批不带扩展名的头文件如iostream,string ,cmath 等。为了兼容C++仍允许使用带扩展名的头文件。由于C语言无命名空间,因此使用带扩展名的头文件时不用using namespace std。
2.3 输入输出变化
C++相对与c程序来说变化不大。头文件从原来的studio.h 文件变成了iostream 标准输入输出流文件,从而输入输出方式也从printf、Scanf,变成cin、 cout 。虽然cin 、cout 输入输出方式简单,但格式设计不方便,而且耗时较大。本质上,c++与c程序区别不大,两者主要区别在于c++使用全新的面向对象思想。
2.4 数据类型
C++基本数据类型有整数类型(int)、字符类型(char)、浮点类型(float)和双精度类型(double)、布尔类型(bool)、空类型(void)六种类型。
2.5 表达式
C++中的表达式有算术表达式(+、-、*、/、%)、赋值表达式(=)、增量表达式(++和--)、关系表达式(>、<、>=、<=、!=)、逻辑表达式(!、&&、||)、条件表达式(操作数1?操作数2:操作数3)、逗号表达式(操作数1,操作数2,…,操作数n)。
2.6 语句
C++中的基本语句有空语句({})、表达式语句、声明语句、条件(if)语句、switch语句、循环语句(for循环语句、while循环语句、do-while循环语句、break语句、continue语句)。
3 类和对象
3.1 类
类是一个全新的概念,与c程序中结构体类似,但与其不同的是类中自带类内函数且在类中数据成员和成员函数的类型分为三种:public、 private、 protected,这三种数据类型有不同的访问权限:public可以被外界直接调用,而private与protected 需要通过函数才能被使用。
类对象:在C++中,对象是类的实际变量。对象的使用格式有 对象名.数据成员名/成员函数名(实参表)。在类的外部,只有公有数据成员和公有成员函数才可以通过类的对象进行访问,而私有数据成员和成员函数只能在类的内部被访问。
4 / 32
Email:572645517@qq.com
Monday, June 24, 2019
3.2 构造函数和析构函数
WangDing
构造函数和析构函数:构造函数和析构函数使类对象能够轻松被创建和撤销。构造函数创建类对象,初始化类成员,析构函数撤销类对象。它们是类的特殊成员函数。
3.3 对象数组与对象指针
对象数组与对象指针:对象数组就是每一个数组元素都是类的对象的数组,对象指针就是用于存放对象地址的变量。对象数组定义的一般格式是 类名 对象数组名[下标表达式],使用方法是 对象数组名[下表表达式].成员名,对象指针的声明方式是 类名*对象指针名。
4 静态成员与友元
4.1 静态成员
在类定义中,类的成员可以用关键字static声明为静态的,这些成员就是静态成员,它被这类所有对象共享。类的私有成员只能在类的内部被访问,在外部要访问时,友元机制提供了很好的途径和方法。
4.2 友元
(1). 友元函数:不是类的成员函数,在外部定义时,不需要加上(::)。在声明为
友元函数时,需要在其函数名前加上关键字friend。
(2). 友元成员:一个类的成员函数要声明为另一个类的友元函数时,必须要先定义这个类。
(3). 友元类:友元类的声明方法是在另一个类中加入形如“friend class 类名”的语句。当一个类做另一个类的友元时,友元类中的所有成员函数都可以访问另一个类的所有成员(包括私有成员)。
5 派生类与继承
5.1 继承
继承是在已有类的基础上创建新类的过程,新类就是派生类,已有类就是基类。
派生类不仅可以继承基类的功能,而且还能对基类的功能进行扩充、修改或重定义。
5.2 派生类
派生类:派生类有三种继承方式,公有继承(public)、私有继承(private)、保护继承(protect)。对于public继承,基类的public和 protect成员分别继承为派生类的public和 protect成员,基类的private成员在派生类中被隐藏。
5 / 32
Email:572645517@qq.com
Monday, June 24, 2019
5.3 继承的两种方式
WangDing
继承:继承有单一继承和多重继承两种方式。
单继承的定义格式是 class 派生类名: 继承方式 基类名{…}。
多重继承的声明方式是 class 派生类名:继承方式1 基类名1,继承方式2 基类名2,……,继承方式n 基类名n{…}。
在C++中,要使公共基类只产生一个拷贝,应该把这个基类声明为虚基类。使用关键字virtual,语法形式是 class 派生类名:virtual 继承方式 基类名{…}。
6 多态性
6.1 多态
多态:多态性是指用一个名字定义不同的函数,这些函数执行不同但又类似的操作。这样可以极大地提高代码利用效率。
6.2 函数重载
函数重载,c++允许定义多个同名函数,只要这些函数属于不同的类或有不同的参数列表(类型,个数或不同类型参数的顺序至少有一个不同)。在调用重载函数时,为某类操作取一个通用的名字,而由编译器解决具体由哪个函数来执行。(析构函数无法重载)
6.3 运算符重载
运算符重载:通过运算符重载可以使运算符在不同的上下文有不同的含义,便于程序功能的实现与修改。
6.4 三大原则
(1). 重载不改变优先级
(2). 重载不改变运算符操作数个数 (3). 重载不能创造新运算符
6.5 模板 6.5.1 模板
模板可以利用以下的代码实现
Template 6 / 32 Email:572645517@qq.com Monday, June 24, 2019 6.5.2 函数模板 WangDing 模板函数可以实现多个不同类型的函数运用同种功能。模板的使用可以进行显示实例化与隐式实例化,同时,函数模板也可以进行重载。 6.5.3 类模板 定义一个类模板是以关键字template开始,定义格式是:template 7 虚函数 当通过基类指针或引用将派生类对象作为基类使用时,覆写机制会失效,即只能访问基类中定义的成员。定义虚函数的方法是 Virtual 返回类型 函数名 (参数表) {、 函数体 } 在派生类中重新定义时,该函数的函数原型(包括返回类型,函数名,参数列表)必须与基类中的函数原型完全相同。注意,一个类的构造函数不能是虚函数,析构函数可以为虚函数。 8 实验内容 8.1 输入3个整数,按由小到大的顺序输出 输入3个整数,按由小到大的顺序输出 输入输出格式如下: 输入: 2 1 3 输出: 1 2 3 设计程序如下: #include Email:572645517@qq.com Monday, June 24, 2019 int a,b,c,*p1,*p2,*p3,*p; cin>>a>>b>>c; p1=&a;p2=&b;p3=&c; if(a>b) {p=p2;p2=p1;p1=p;} WangDing else { if(b>c) {p=p3;p3=p2;p2=p;} if(a>c) {p=p3;p3=p2;p2=p;} } cout<<*p1<<\" \"<<*p2<<\" \"<<*p3; } while (1) { } return 0; ; 8.2 输入3个字符串,按由小到大的顺序输出 输入3个字符串,按由小到大的顺序输出 输入输出格式如下 输入 cba abc bac 8 / 32 Email:572645517@qq.com Monday, June 24, 2019 输出 abc bac cba 设计程序如下: #include 9 / 32 Email:572645517@qq.com Monday, June 24, 2019 WangDing 8.3 写一函数,将一个3X3的矩阵转置 写一函数,将一个3X3的矩阵转置 提示:矩阵可存放到二维数组中,用指针完成数的交换(swap)操作 输入输出示例如下 输入 1 2 3 4 5 6 7 8 9 输出 1 4 7 2 5 8 3 6 9 设计程序如下: #include Email:572645517@qq.com Monday, June 24, 2019 for(j=0;j<3;j++) cin>>a[i][j]; p=a; q=a[0]; for(i=0;i<3;i++) for(j=i;j<3;j++) { t=*(q+3*i+j); *(q+3*i+j)=*(q+3*j+i); *(q+3*j+i)=t; } for(p=a;p8.4 两个字符串的比较 写一个函数,实现两个字符串的比较。即自己写一个strcmp函数,函数原型为 int strcmp(char * p1,char * p2) 设p1指向字符串s1,p2指向字符串s2。要求当s1=s2时,返回值为0;若s1≠s2时,返回它们二者第1个不同字符的ASCII码差值(如“BOY”与“BAD”,第2个字母不同,“O”与“A”之差为79-65=14)。如果s1>s2,则输出正值;如果s1 11 / 32 Email:572645517@qq.com Monday, June 24, 2019 输出 14 设计程序如下: #include char a[100],b[100]; char *x,*y; int k; int strcmp(char *p,char *o); cin>>a>>b; x=a; y=b; k=strcmp(x,y); cout< int i,k; k=0; for(i=0;(*(p+i)!='\\0')||(*(o+i)!='\\0');i+=1) { if (*(p+i)==*(o+i)) k=0; else { k=*(p+i)-*(o+i); break; } } return k; } 12 / 32 WangDing Email:572645517@qq.com Monday, June 24, 2019 WangDing 8.5 输出100以内的所有素数 编写C++风格的程序,输出100以内的所有素数。 主:各个素数之间用空格隔开。 设计程序如下: