友元函数和友元类

友元函数是指某些虽然不是类成员却能够访问类的所有成员的函数。。类授予它的友元特别的访问权。通常同一个开发者会出于技术和非技术的原因,控制类的友元和成员函数(否则当你想更新你的类时,还要征得其它部分的拥有者的同意)。

// Friend.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "math.h"

class Point
{
private:
 double m_X;
 double m_Y;
public:
 friend double Distance(Point pt0, Point pt1)
 {
  return sqrt((pt0.m_X - pt1.m_X) * (pt0.m_X - pt1.m_X) + (pt1.m_Y - pt0.m_Y) * (pt1.m_Y - pt0.m_Y));
 }
 Point(double mx, double my)
 {
  m_X = mx;
  m_Y = my;
 }
 ~Point()
 {

 }
};

int main(int argc, char* argv[])
{
 Point pnt0(3,0);
 Point pnt1(0,4);
 printf("%f", Distance(pnt0, pnt1));

 //printf("Hello World!\n");
 return 0;
}

 一个类A声明为一个类B的友元类之后,类A就可以任意访问类B的所有 成员(公有的,保护的和私有的).但是,如果一个类D继承自类B, 类B中的友元关系并不会被继承,也就是说,类A是类B的友元但却不是 类B的派生类D的友元.即类A不可以访问类D的保护的和私有的成员. 在上面的代码中,被注释了的部分不能够通过编译,因为D不是A的友 元类,B的友元关系并没有被继承.而在A的Print函数成员中,参数为 基类B的const引用;而实参却可以是D类的对象,从而实现了在A类中 调用D类成员的目的.当然,你完全可以把A声明为D的友元类.对这种 机制的解释:首先,在A的Print函数中,通过B类对象调用其私有的虚 函数(b.Print();),由于A是B的友元,该调用是完全合法的.而在用 D对象调用A的Print函数时时,b.Print()调用动态绑定到了对D类对象 的函数版本的调用.这里,也说明了另外一个问题:类成员的访问控制 只是在编译时有效。

#include "stdafx.h"
#include <iostream>
using namespace std;
#include "math.h"

class B
{
 friend class A;
private:
 virtual void Print()
 {
  std::cout<<"B"<<endl;
 }
};
class D : public B
{
private:
 virtual void Print()
 {
  std::cout<<"D"<<endl;
 }
};
class A
{
public:
 A()
 {
  B b;
  cout<<"A's Constructor";
  b.Print();
 }
 void Print(B & b)
 {
  cout<<"A-->";
  b.Print();
 }
};
int main(int argc, char* argv[])
{
 A a;
 B b;
 D d;
 a.Print(b);
 a.Print(d);
 return 0;
}

转载于:https://www.cnblogs.com/flying-roc/archive/2011/05/03/2035116.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/263520.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode—216. 组合总和 III

216. 组合总和 III 题目描述&#xff1a; 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9 每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次&#xff0c;组合可以以任何顺序返回。 考察重…

发表和编辑Post的一个Bug

其实这个Bug很早以前就发现了&#xff0c;只是一直忘了问dudu。在写Post的时候&#xff0c;当我需要改变字体颜色&#xff0c;例如选择红色时&#xff0c;文字的字体发生了改变。但当我第二次选择字体颜色&#xff0c;且选择相同的颜色时&#xff0c;选中的文字颜色就没有发生变…

maven配置_eclipse创建maven_maven插件配置

为什么80%的码农都做不了架构师&#xff1f;>>> 最近项目开发中需要使用maven。Maven这个东西是我2年前自学的。这2年之中基本没有使用过。现在项目需要&#xff0c;只有重新来一遍回锅肉。重新学习。经过一下午的斗争&#xff0c;一下午的各种问题各种解决&#x…

收藏

源码解析&#xff1a;http://www.iocoder.cn/categories/Sharding-JDBC/?cnblog java源码&#xff1a;http://blog.csdn.net/javazejian js 火狐文档&#xff1a;https://developer.mozilla.org/zh-CN/docs/Web/JavaScript NIO:http://www.iteye.com/magazines/132-Java-NIO J…

老生又长谈:HttpApplication,HttpModule,HttpContext及Asp.Net页生命周期

IIS在接到一个新的http请求后&#xff0c;最终会调用asp.net_isapi.dll的ISAPI扩展(特指IIS6.0环境&#xff0c;iis7.0的应用程序池默认为集成方式&#xff0c;相对有所变化)&#xff0c;然后传递到httpRuntime Pipe(http运行时管道)&#xff0c;Asp.Net这时才开始运行(即HttpR…

LeetCode—220. 存在重复元素 III

220. 存在重复元素 III 题目描述&#xff1a; 给你一个整数数组 nums 和两个整数 k 和 t 。请你判断是否存在 两个不同下标 i 和 j&#xff0c;使得 abs(nums[i] - nums[j]) < t &#xff0c;同时又满足 abs(i - j) < k 。 如果存在则返回 true&#xff0c;不存在返回 …

德里达逝世了!

放个标题在这里吧&#xff0c;追悼一下&#xff0e;-----------------------------------------------------某个人&#xff0c;您或者我&#xff0c;走上前来说&#xff1a;“最终&#xff0c;我要学会生活” !"生活&#xff0c;能够学会吗&#xff1f;能够教吗&#xff…

关于活动对像要注意的问题

如果用 RTime 中的 AT 方法&#xff0c;则这个时间不能比现在的时间小&#xff0c;否则 iStatus.Int() 将返回 -10 KErrUnderflow 这个错误 转载于:https://www.cnblogs.com/zziss/archive/2011/05/06/2039094.html

ByteBuffer常用方法详解

缓冲区(Buffer)就是在内存中预留指定大小的存储空间用来对输入/输出(I/O)的数据作临时存储&#xff0c;这部分预留的内存空间就叫做缓冲区&#xff1a; 使用缓冲区有这么两个好处&#xff1a; 1、减少实际的物理读写次数 2、缓冲区在创建时就被分配内存&#xff0c;这块内存区域…

LeetCode—221. 最大正方形

221. 最大正方形 题目描述&#xff1a; 在一个由 ‘0’ 和 ‘1’ 组成的二维矩阵内&#xff0c;找到只包含 ‘1’ 的最大正方形&#xff0c;并返回其面积。 考察重点&#xff1a;动态规划 方法概括&#xff1a;二维矩阵中查询最大矩形 dp[i][j] Min(dp[i-1][j],dp[i][j-1]…

发布Activex

1、如果需要创建cab文件&#xff0c;首先需要Cabarc或者Makecab&#xff0c;它们随着Cabinet SDK的安装就有了&#xff0c;Cabinet SDK的下载地址是http://msdn.microsoft.com/workshop/management/cab/cabdl.asp。 Cabarc可以创建、查看或者解出cab里面的文件&#xff0c;而…

做汉堡

其实我还是不太明白为什么要叫做汉堡&#xff0c;虽然我很喜欢吃汉堡..... 对于上次结对子作业的队友&#xff0c;小伙伴&#xff0c;我只想说一个字赞&#xff01;前所未有的感觉&#xff08;夸张了点&#xff09;... first&#xff0c;我们对整个任务没有做出工作量分析&…

Egret入门学习日记 --- 第二篇

第二篇&#xff08;学习篇&#xff09; 既然选好了Egret&#xff0c;那我就要想想怎么学了。 开始第一步&#xff0c;先加个Q群先&#xff0c;这不&#xff0c;拿到了一本《Egret HTML5游戏开发指南》&#xff0c;阅至三章&#xff0c;得到印象相对较深的好处和坏处&#xff1…

参加Sun公司的新产品的发布会议

在2004年的最后阶段&#xff0c;能收到Sun公司的邀请函&#xff0c;去参加“Sun秋季产品发布会”&#xff0c;是在沈阳的丽都喜来登酒店&#xff0c;幸运的是&#xff0c;这次地点是上次微软公司msdn发布会的邻居&#xff0c;也是五星级别的。不过这次去的时候&#xff0c;小妹…

LeetCode—222. 完全二叉树的节点个数

222. 完全二叉树的节点个数 题目描述&#xff1a; 给你一棵 完全二叉树的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达到最大值&#xff0c;并且最下…

编程珠玑读书笔记之磁盘文件排序

输入&#xff1a; 所输入的是一个文件&#xff0c;至多包含n个正整数&#xff0c;每个正整数都要小于n&#xff0c;这是 n 10^7。如果输入时某个整数出现了两次&#xff0c;就会产生一个致命的错误。这些整数与其他任何数据都不关联。 输出&#xff1a; 以增序形式输出的经过排…

辨别文件的真实类型

2019独角兽企业重金招聘Python工程师标准>>> 参考博客http://blog.csdn.net/shixing_11/article/details/5708145 每个文件类型都对应着一个编码头部 下面这些是已知的文件头部[自定义的枚举类型] package org.masque.file; /*** * Description:文件对应的文件头,资…

ng build --prod --aot打包Angluar4项目报javaScript heap out of memory,内存溢出

这里 Allocation failed - JavaScript heap out of memory JavaScript堆内存不足&#xff0c;我们都知道 Node 是基于V8引擎&#xff0c;在一般的后端开发语言中&#xff0c;在基本的内存使用上没有什么限制&#xff0c;但是我去查阅了相关的资料才发现&#xff0c;在 Node 中通…

GARFIELD@12-02-2004

your BELLY is more ready to be convinced than your BRAIN 转载于:https://www.cnblogs.com/rexhost/archive/2004/12/02/72000.html

LeetCode—223. 矩形面积

223. 矩形面积 题目描述&#xff1a; 给你 二维 平面上两个 由直线构成且边与坐标轴平行/垂直 的矩形&#xff0c;请你计算并返回两个矩形覆盖的总面积。 每个矩形由其 左下 顶点和 右上 顶点坐标表示&#xff1a; 第一个矩形由其左下顶点 (ax1, ay1) 和右上顶点 (ax2, ay2)…