您的位置:首页 > 其它

第七周项目1-点类-友元函数

2016-04-09 19:49 435 查看
问题及代码:

/*
*Copyright (c) 2016,烟台大学计算机学院
*All rights reserved.
*文件名称:zwj.cpp
*作 者:张伟晶
*完成日期:2016年4月9日
*版 本 号:v1.0
*
*问题描述:用友元函数设计点类求两点之间的距离
*输入描述:
*程序输出:两点间距离
*/
#include<iostream>
#include<cmath>
using namespace std;

class CPoint
{
private:
double x; // 横坐标
double y; // 纵坐标
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy){}
double getx(){return x;}
double gety(){return y;}
friend double line(CPoint &p1,CPoint &p2); //友元函数的声明

};

/*
class Line
{
public:
Line(CPoint xp1,CPoint xp2);
Line (Line &l);
double getlen(){return len;}
private:
CPoint p1,p2;
double len;
};
*/
double line(CPoint &p1,CPoint &p2)
{
double x=p1.x-p2.x;
double y=p1.y-p2.y;
return sqrt(x*x+y*y);
}
int main()
{
CPoint p1(1,1),p2(4,6.2);
// Line line(p1,p2);
cout<<"p1为:("<<p1.getx()<<","<<p1.gety()<<")"<<endl;
cout<<"p2为:("<<p2.getx()<<","<<p2.gety()<<")"<<endl;
cout<<"两点间距离为:"<<line(p1,p2)<<endl;
return 0;
}

运行结果:



知识点总结:

友元函数的定义与使用。

学习心得:

友元函数是指某些虽然不是类成员却能够访问类的所有成员的函数。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: