C++友元初步

栏目: C++ · 发布时间: 6年前

内容简介:本例对C++友元的使用从代码上作了一个简单的归纳,但不仅限于本问讲到的用法,友元还可以重载等。**/

本例对C++友元的使用从代码上作了一个简单的归纳,但不仅限于本问讲到的用法,友元还可以重载等。

**

/ 全局函数作为友元 /

**

include <iostream>

include <cmath>

using namespace std;

class Point{

public:

Point(double x, double y){
    _x = x;
    _y = y;
}
void getFormatxy();
friend double distance(Point &a, Point &b);

private:

double _x, _y;

};

void Point::getFormatxy(){

cout<<"("<<_x<<","<<_y<<")"<<endl;

}

double distance(Point &a, Point &b){

double dx = a._x - b._x;
double dy = a._y - b._y;
return sqrt(dx*dx + dy*dy);

}

int main()

{

Point p1(3.0, 4.0), p2(6.0, 8.0);
p1.getFormatxy();
p2.getFormatxy();
double d = distance(p1, p2);
cout<<"distance is "<<d<<endl;
return 0;

}

**

/ 一个类的成员函数作友元 /

**

include <iostream>

include <cmath>

using namespace std;

class Point; //前向声明,用于声明。

class ManagerPoint{

public:

double distance(Point &a, Point &b);

};

class Point{

public:

Point(double x, double y){
    _x = x;
    _y = y;
}
void getFormatxy();
friend double ManagerPoint::distance(Point &a, Point &b);

private:

double _x, _y;

};

void Point::getFormatxy(){

cout<<"("<<_x<<","<<_y<<")"<<endl;

}

double ManagerPoint::distance(Point &a, Point &b){

double dx = a._x - b._x;
double dy = a._y - b._y;
return sqrt(dx*dx +dy*dy);

}

int main()

{

Point p1(3.0, 4.0), p2(6.0, 8.0);
p1.getFormatxy();
p2.getFormatxy();
ManagerPoint mp;
float d = mp.distance(p1, p2);
cout<<"distance is"<<d<<endl;
return 0;

}

**

/ 友元类 /

**

include <iostream>

include <cmath>

using namespace std;

class Point{

public:

friend class ManagerPoint;
Point(double x, double y){
    _x = x;
    _y = y;
}
void getFormatxy();

private:

double _x, _y;

};

void Point::getFormatxy(){

cout<<"("<<_x<<","<<_y<<")"<<endl;

}

class ManagerPoint{

public:

double distance(Point &a, Point &b);

};

double ManagerPoint::distance(Point &a, Point &b){

double dx = a._x - b._x;
double dy = a._y - b._y;
return sqrt(dx*dx + dy*dy);

}

int main()

{

Point p1(3.0, 4.0), p2(6.0, 8.0);
p1.getFormatxy();
p2.getFormatxy();
ManagerPoint mp;
float d = mp.distance(p1, p2);
cout<<"distance is"<< d<<endl;
return 0;

}

**

/ 友元小结 /

**

//友元声明以关键字friend开始,它只能出现在类定义中

//因为友元不是类授权的成员,所以它不受其所在区域的public private 和protected 的影响

//通常,把所有友元声明组织在一起并放在类头之后.

//友元利弊:

//友元不是类成员,但是它可以通过对象访问类中的私有成员,友元的作用在于提高程序的运行效率

//但是,它破坏了封装性,使得非成员函数可以访问类的私有成员

//注意: 友元关系不能被继承,友元关系不具有传递性

include <iostream>

using namespace std;

class Time{

public:

friend class Watch;
Time(int hour, int min, int sec){
    m_iHour = hour;
    m_iMinute = min;
    m_iSecond = sec;
}

private:

int m_iHour;
int m_iMinute;
int m_iSecond;

};

class Watch{

public:

Watch(Time t): m_tTime(t){}
void display(){
    cout<<m_tTime.m_iHour<<endl;
    cout<<m_tTime.m_iMinute<<endl;
    cout<<m_tTime.m_iSecond<<endl;
}

public:

Time m_tTime;

};

int main()

{

Time t(6, 30, 20);
Watch w(t);
w.display();
return 0;

}


以上所述就是小编给大家介绍的《C++友元初步》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

颠覆营销

颠覆营销

陈杰豪、车品觉 / 中信出版社 / 2016-2 / 49.00元

对于大数据未来趋势的判断 车品觉 光阴荏苒,2015年在跌跌荡荡中成了过去式,对于大数据的产业来说过去这一年冒出了很多新的名词。但在我看来,真正的大数据应用和市场才刚刚开始萌芽,所以我希望大家先认清一个关键,那就是所有的数据都是基于应用而产生,而数据经过釆集及整合后又再落实到自身或其他应用情境中,大数据的创新价值可以来自新连接的数据、算法或者产品本身。 过去两年大数据的成长和智能......一起来看看 《颠覆营销》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

在线进制转换器
在线进制转换器

各进制数互转换器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试