- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告
实验目的
通过这些题目的训练,需要掌握静态数据成员以及静态成员函数的使用方法,友元函数的使用,以及掌握构造函数和析构函数,拷贝构造函数、内联成员函数、聚集的使用,熟练的使用类解决问题。
实验环境
编译器:Visual c++6.0
操作系统:Windows XP
三、实验题目
基础题1:
题目:定义一个Cat类,拥有静态数据成员HowManyCats,记录Cat的个体数目;静态成员函数GetHowMany(),存取HowManyCats。设计程序测试这个类,体会静态数据成员和静态成员函数的用法。
分析:定义一个名为Cat类,静态数据成员HowManyCats,记录Cat的个体数目,静态成员函数GetHowMany(),输入一只Cat的名字就让HowManyCats加1,调用静态成员函数GetHowMany()输出数目即可。
核心代码:
#includeiostream
using namespace std;
class Cat//定义一个Cat类
{
public:
Cat(char Name)//定义一个构造函数,形参为Cat的名字
{
CatName=Name;
HowManyCats++;
}
static void GetHowMany()
{
coutthe number of cats: HowManyCatsendl;
}
private:
char CatName;
static int HowManyCats;
};
int Cat::HowManyCats=0;//静态数据成员声明
void main()
{
char _name;
int W=0;
do
{ coutplease input the name of one cat(一个字母):endl;
cin_name;
W=1;
Cat c(_name);
coutif you want to contiue to input cat,please input 0 or else input 1.endl;
cinW;
}while(W==0);
Cat::GetHowMany();//静态成员函数调用
}
程序运行及截图:
总结:掌握静态成员函数的定义与实现,以及静态数据成员的声明、定义和初始化方法,学会使用类解决实际问题。
基础题2:
题目:设计一个点(point)类, 1)在点类中设计友员函数,求两点间的距离。 2)设计一个线段(line)类。
分析:定义一个Point类,在其中设置一个友元函数求两点的距离,以及定义一个Line类用Point类型的数据成员求其长度,即求两点的距离。
核心代码:
#includeiostream
#includemath.h
using namespace std;
class Point//定义一个Point类
{
public:
Point(double NewX=0.0,double NewY=0.0)
{
x=NewX;
y=NewY;
}
double GetX()
{
return x;
}
double GetY()
{
return y;
}
friend double dist(Point p1,Point p2);//友元函数声明
private:
double x,y;
};
double dist(Point p1,Point p2)//友元函数实现
{
double x=p1.x-p2.x;
double y=p1.y-p2.y;
return static_castdouble ( sqrt (x*x+y*y));
}
class line//定义一个线段类
{
public:
line(Point Np1,Point Np2);
double getlen()
{
return len;
}
private:
Point p1,p2;
double len;//长度
};
line::line(Point Np1,Point Np2):p1(Np1),p2(Np2)//构造函数求线段长度
{
double x=static_castdouble(p1.GetX()-p2.GetX());
double y=static_castdouble(p1.GetY()-p2.GetY());
len=sqrt(x*x+y*y);
}
void main()
{
double x1,y1,x2,y2;
coutplease input two points(x1,y1,x2,y2):endl;
cinx1y1x2y2;
Point myp1(x1,y1),myp2(x2,y2);//构造两个点
coutthe distant is: ;
coutdist(myp1,
您可能关注的文档
最近下载
- 临床医学 《门静脉高压症》教学课件.ppt VIP
- 最新:机械通气患者转运课件.pptx VIP
- 最新清晰版ISO50001(中word版).docx VIP
- (高清版)DB44∕T 2598-2024 《省级体育社会团体建设规范》.pdf VIP
- 现浇钢筋混凝土楼板施工工艺.pdf VIP
- 装修贷款业务培训.pptx VIP
- 建筑施工岗位安全风险告知卡(完整共十张).pdf VIP
- 最新清晰版ISO50001(中文PDF版).pdf VIP
- 磁性材料分类与应用.ppt VIP
- Unit 2 Learning English is fun! 单元拔尖检测(含答案及听力音频)冀教版英语七年级上册.doc VIP
文档评论(0)