/*
*Copyright (c) 2016,烟台大学计算机学院
*All rights reserved.
*文件名称:text.cpp
*作者:汤善晔
*完成日期:2016年6月9日
*版本号:v1.0
*问题描述:友元函数求两点间的距离
*输入描述:输入两点的坐标
*程序输出:输出两点间的距离
*/
#include <iostream>
#include<cmath>
using namespace std;
class Cpoint
{
private:
double x;
double y;
public:
Cpoint(double m=0,double n=0):x(m),y(n){}
void setx(double m);
void sety(double n);
double putx();
double puty();
friend void showCpoint(Cpoint &a,Cpoint &b);
};
void Cpoint::setx(double m)
{
x=m;
}
void Cpoint::sety(double n)
{
y=n;
}
double Cpoint::putx()
{
return x;
}
double Cpoint::puty()
{
return y;
}
void showCpoint(Cpoint &a,Cpoint &b)
{
double x=a.x-b.x;
double y=a.y-b.y;
cout<<sqrt(x*x+y*y)<<endl;
}
void show(Cpoint a,Cpoint b)
{
double x=a.putx()-b.putx();
double y=a.puty()-b.puty();
cout<<sqrt(x*x+y*y)<<endl;
}
int main()
{
Cpoint a(3,3),b(1,1);
show(a,b);
showCpoint(a,b);
return 0;
}
运用求两点间的距离,来解释友元函数的定义,友元函数可以特殊的调用私有成员