现在的位置: 首页 > 综合 > 正文

7-2 友元函数(Time类)

2013年09月22日 ⁄ 综合 ⁄ 共 1531字 ⁄ 字号 评论关闭

/*
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:                             
* 作    者: 张传新                            
* 完成日期:2012  年04月02 日
* 版 本 号:1.0         

* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:使用成员函数、友元函数和一般函数的区别
* 程序输出:
* 问题分析:……
* 算法设计:……
*/

#include<iostream>   
#include<cmath>   
using namespace std;     
class CPoint  
{  
private:  
	double x;  // 横坐标   
	double y;  // 纵坐标   
public:  
	CPoint(double xx=1,double yy=2):x(xx),y(yy){}  
	double Distance1(CPoint p,CPoint q);   // 两点之间的距离
       friend double Distance2(CPoint p,CPoint q); //友元函数声明
	int getx(){return x;}
	int gety(){return y;}
	void input();  //以x,y 形式输入坐标点   
	void output(); //以(x,y) 形式输出坐标点   
};
double Distance3(CPoint p,CPoint q); //一般函数声明
 
void main()  
{  
	
	CPoint a1;  
	CPoint a2;  
	a1.input();  
	a1.output();  
	a2.input();  
	a2.output(); 
	a1.Distance1(a1,a2);
	Distance2(a1,a2);
	Distance3(a1,a2);
	system("pause");  
}  

void CPoint::input()   
{  
	char a;  
	cout<<"请以“x,y ”形式输入坐标点:"<<endl;  
	cin>>x>>a>>y;  
	if(a!=',')  
	{  
		exit(0);  
	}  
}  

//以(x,y) 形式输出坐标点
void CPoint::output()    
{  
	cout<<"("<<x<<","<<y<<")"<<endl;  
}  

// 两点之间的距离(一点是当前点,另一点为参数p)  
double CPoint::Distance1(CPoint p,CPoint q) //成员函数的实现,Distance1前加CPoint::
{  
	cout<<"两点的距离为:"<<endl;  
	cout<<sqrt((q.x-p.x)*(q.x-p.x)+(q.y-p.y)*(q.y-p.y))<<endl;  
	return 0;  
}  
double Distance2(CPoint p,CPoint q)//友元函数的实现,Distance2前不加CPoint::,并不是类的成员函数
{	cout<<"两点的距离为:"<<endl;  
	cout<<sqrt((q.x-p.x)*(q.x-p.x)+(q.y-p.y)*(q.y-p.y))<<endl;  
	return 0;  
}

double Distance3(CPoint p,CPoint q)//只能用公共接口q.getx()形式访问私有数据成员
{  
	cout<<"两点的距离为:"<<endl;  
	cout<<sqrt((q.getx()-p.getx())*(q.getx()-p.getx())+(q.gety()-p.gety())*(q.gety()-p.gety()))<<endl;  
	return 0;  
}    

运行结果:

经验积累:
1.三个版本的求两点之间的距离的函数,让我对于这三种函数的使用更加明确。

上机感言:friend函数使两个“人”之间的关系更加密切。。。

抱歉!评论已关闭.