博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第六周项目4-成员函数、友元函数和一般函数有区别
阅读量:6580 次
发布时间:2019-06-24

本文共 2890 字,大约阅读时间需要 9 分钟。

(1)阅读下面的程序,体会注释中的说明。
//例:使用成员函数、友元函数和一般函数的区别#include 
using namespace std;class Time{public: Time(int h,int m,int s):hour(h),minute(m),sec(s) {} void display1(); //display1是成员函数 friend void display2(Time &); //display2是友元函数 int getHour(){return hour;} int getMinute(){return minute;} int getSec(){return sec;}private: int hour; int minute; int sec;};void Time::display1() //成员函数display1的实现,dispaly1前加Time::{ //以hour形式直接访问私有数据成员,实质是this->hour形式 cout<
<<":"<
<<":"<
<
(2)模仿上面的示例,完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。

提示:此项目和例子的区别在于“距离是一个点和另外一个点的距离”,不同版本在参数上有体现。三个版本建议分开测试,也可以如示例,放在一个程序中完成。

成员函数:

/** Copyright (c) 2015,烟台大学计算机学院* All right reserved.* 作者:邵帅* 文件:Demo.cpp* 完成时间:2015年04月16日* 版本号:v1.0*/#include
#include
using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0):x(xx),y(yy) {} double Distance(CPoint p); void input(); void output();};double CPoint::Distance(CPoint p){ double s; s=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y)); return s;}void CPoint::input(){ char ch; cout<<"请输入坐标(x,y):"; cin>>x>>ch>>y;}void CPoint::output(){ cout<<"("<
<<", "<
<<")"<

友元函数

/** Copyright (c) 2015,烟台大学计算机学院* All right reserved.* 作者:邵帅* 文件:Demo.cpp* 完成时间:2015年04月16日* 版本号:v1.0*/#include
#include
using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0):x(xx),y(yy) {} friend double Distance(CPoint &,CPoint &); void input(); void output();};double Distance(CPoint &p1,CPoint &p2){ double s; s=sqrt((p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y)); return s;}void CPoint::input(){ char ch; cout<<"请输入坐标(x,y):"; cin>>x>>ch>>y;}void CPoint::output(){ cout<<"("<
<<", "<
<<")"<

一般函数

/** Copyright (c) 2015,烟台大学计算机学院* All right reserved.* 作者:邵帅* 文件:Demo.cpp* 完成时间:2015年04月16日* 版本号:v1.0*/#include
#include
using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0):x(xx),y(yy) {} void input(); void output(); double getx() { return x; }; double gety() { return y; };};double Distance(CPoint &,CPoint &);double Distance(CPoint &p1,CPoint &p2){ double s; s=sqrt((p1.getx()-p2.getx())*(p1.getx()-p2.getx())+(p1.gety()-p2.gety())*(p1.gety()-p2.gety())); return s;}void CPoint::input(){ char ch; cout<<"请输入坐标(x,y):"; cin>>x>>ch>>y;}void CPoint::output(){ cout<<"("<
<<", "<
<<")"<

@ Mayuko

转载于:https://www.cnblogs.com/mayuko/p/4567508.html

你可能感兴趣的文章
POJ2739:Sum of Consecutive Prime Numbers(简单数论)
查看>>
c#和.net区别
查看>>
java的环境变量classpath中加点号 ‘.’ 的作用
查看>>
采用CAN芯片实现和FPGA通信
查看>>
动态规划算法3
查看>>
框架搭建
查看>>
关于增强for循环
查看>>
冒泡排序法
查看>>
选择排序
查看>>
Valid Phone Numbers
查看>>
ffmpeg 安装
查看>>
Django基础之中间件
查看>>
VS code
查看>>
MySQL学习基础
查看>>
我们都是程序员(四个男人三个女人的故事下)
查看>>
在升级版数据的收集和赋值。只针对上篇文章。
查看>>
发布订阅模式
查看>>
linux安装ActiveMQ
查看>>
ubuntu 中文变成小方框 口
查看>>
mybatis的decimal精度缺失
查看>>