第六周 项目四:成员函数、友元函数和一般函数有区别

问题及代码:

/*
* Copyright (c) 2015, 烟台大学计算机学院
* All rights reserved.
* 文件名称:read.cpp
* 作    者:李楠
* 完成日期:2015年4月9日
* 版 本 号:v1.0
*
* 问题描述:(2)模仿上面的示例,完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。
             提示:此项目和例子的区别在于“距离是一个点和另外一个点的距离”,不同版本在参数上有体现。三个版本建议分开测试,也可以如示例,放在一个程序中完成。
             下面是点类的部分代码。
* 程序输入:略
* 程序输出:略
*/
#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){}
    void Distance1(CPoint p) const;//两点之间的距离(一点是当前点——想到this了吗?,另一点为p)
    friend void Distance2(CPoint &t,CPoint &p);
    void Distance3(CPoint &t,CPoint &p);
    double outputx();
    double outputy();
};
void CPoint::Distance1(CPoint p) const  //成员函数display1的实现,dispaly1前加Time::
{
    double l;
    l=sqrt((this->x-p.x)*(this->x-p.x)+(this->y-p.y)*(this->y-p.y));
    cout<<l<<endl;
}
void Distance2(CPoint &t,CPoint &p)  //友元函数dispaly2的实现,不加Time::,友元并不是类的成员
{
    double l;
    l=sqrt((p.x-t.x)*(p.x-t.x)+(p.y-t.y)*(p.y-t.y));
    cout<<l<<endl;
}
void Distance3(CPoint &t,CPoint &p)  //display3是一般函数,dispaly3前不加Time::
{
    double l;
    l=sqrt((p.outputx()-t.outputx())*(p.outputx()-t.outputx())+(p.outputy()-t.outputy())*(p.outputy()-t.outputy()));
    cout<<l<<endl;
}
double CPoint::outputx()
{
    return x;
}
double CPoint::outputy()
{
    return y;
}
int main()
{
    CPoint P1(3.0,4.0);
    CPoint P2;
    P1.Distance1(P2);  //成员函数这样调用:对象名.函数名()
    Distance2(P1,P2);   //友员函数的调用和一般函数无异(但实现中可以不同)
    Distance3(P1,P2);   //一般函数的调用
    return 0;
}


运行结果:

 

知识点总结:
根据所给的例子,写出友元函数,注意函数的参数和例子不太一样~
学习心得:
懂得举一反三,并且能从中领悟到道理~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值