什么是友元类[通俗易懂]

什么是友元类[通俗易懂]======================什么是友元类=======================     当一个类B成为了另外一个类A的“朋友”时,那么类A的私有和保护的数据成员就可以被类B访问。我们就把类B叫做类A的友元。=======================友元类能做什么=======================     友元类可以通过自己的方法来

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

======================什么是友元类=======================

      当一个类B成为了另外一个类A的“朋友”时,那么类A的私有和保护的数据成员就可以被类B访问。我们就把类B叫做类A的友元。

=======================友元类能做什么=======================

      友元类可以通过自己的方法来访问把它当做朋友的那个类的所有成员。但是我们应该注意的是,我们把类B设置成了类A的友元类,但是这并不会是类A成为类B的友元。说白了就是:甲愿意把甲的秘密告诉乙,但是乙不见得愿意把乙自己的秘密告诉甲。

=======================友元类的声明方法和其用法=======================

      声明友元类的方法其实很简单,只要我们在类A的成员列表中写下如下语句:

friend 
class 
B;

  这样一来,类B就被声明成了类A的友元。注意,类B虽然是类A的友元,但是两者之间不存在继承关系。这也就是说,友元类和原来那个类之间并没有什么继承关系,也不存在包含或者是被包含的关系,友元类和我上一篇博文《谈谈:C++类的“包含”机制》中的包含是完全不一样的!

=======================友元类的一个具体例子=======================

      在这里,我们引用一个我从网上收集到的例子来说明友元类的作用:假设我们要设计一个模拟电视机和遥控器的程序。大家都之道,遥控机类和电视机类是不相包含的,而且,遥控器可以操作电视机,但是电视机无法操作遥控器,这就比较符合友元的特性了。即我们把遥控器类说明成电视机类的友元。下面是这个例子的具体代码:

#include <iostream>
using 
namespace 
std;
class 
TV
{
    
public
:
      
friend 
class 
Tele;
      
TV():on_off(off),volume(20),channel(3),mode(tv){}
    
private
:   
      
enum
{on,off};
      
enum
{tv,av};
      
enum
{minve,maxve=100};
      
enum
{mincl,maxcl=60};
      
bool 
on_off;
      
int  
volume;
      
int 
channel;
      
int 
mode;
};
class 
Tele
{
    
public
:
       
void 
OnOFF(TV&t){t.on_off=(t.on_off==t.on)?t.off:t.on;}
       
void 
SetMode(TV&t){t.mode=(t.mode==t.tv)?t.av:t.tv;}
       
bool 
VolumeUp(TV&t);
       
bool 
VolumeDown(TV&t);
       
bool 
ChannelUp(TV&t);
       
bool 
ChannelDown(TV&t);
       
void 
show(TV&t)
const
;   
};
bool 
Tele::VolumeUp(TV&t)
{
    
if 
(t.volume<t.maxve)
    
{
        
t.volume++;
        
return 
true
;
    
}
    
else
    
{
        
return 
false
;
    
}
}
bool 
Tele::VolumeDown(TV&t)
{
    
if 
(t.volume>t.minve)
    
{
        
t.volume--;
        
return 
true
;
    
}
    
else
    
{
        
return 
false
;
    
}
}
bool 
Tele::ChannelUp(TV&t)
{
    
if 
(t.channel<t.maxcl)
    
{
        
t.channel++;
        
return 
true
;
    
}
    
else
    
{
        
return 
false
;
    
}
}
bool 
Tele::ChannelDown(TV&t)
{
    
if 
(t.channel>t.mincl)
    
{
        
t.channel--;
        
return 
true
;
    
}
    
else
    
{
        
return 
false
;
    
}
}
void 
Tele::show(TV&t)
const
{
    
if 
(t.on_off==t.on)
    
{
        
cout<<
"电视现在"
<<(t.on_off==t.on?
"开启"
:
"关闭"
)<<endl;
        
cout<<
"音量大小为:"
<<t.volume<<endl;
        
cout<<
"信号接收模式为:"
<<(t.mode==t.av?
"AV"
:
"TV"
)<<endl;
        
cout<<
"频道为:"
<<t.channel<<endl;
 
    
}
    
else
    
{
        
cout<<
"电视现在"
<<(t.on_off==t.on?
"开启"
:
"关闭"
)<<endl;
    
}
     
}
int 
main()
{
    
Tele t1;
    
TV t2;
    
t1.show(t2);
    
t1.OnOFF(t2);
    
t1.show(t2);
    
cout<<
"调大声音"
<<endl;
    
t1.VolumeUp(t2);
    
cout<<
"频道+1"
<<endl;
    
t1.ChannelUp(t2);
    
cout<<
"转换模式"
<<endl;
    
t1.SetMode(t2);
    
t1.show(t2);
    
return 
0;
}

      我们在程序的第6行定义了一个TV电视机类的友元类Tele。那么程序中就可以来调用TV类中的私有成员。下面,是该程序的输出:

什么是友元类[通俗易懂]

      好了,这就是友元类了。关于友元类,我反正是这样认为的,因为友元类有可能会破坏数据的安全性,我们还是少用为好啊!在这里我只是记录一下它的用法罢了,呵呵

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234801.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 理解零拷贝_零拷贝技术

    理解零拷贝_零拷贝技术零拷贝是Netty的重要特性之一,而究竟什么是零拷贝呢? WIKI中对其有如下定义:“Zero-copy”describescomputeroperationsinwhichtheCPUdoesnotperformthetaskofcopyingdatafromonememoryareatoanother.从WIKI的定义中

    2022年9月2日
    6
  • HashMap 与 ConcurrentHashMap 原理总结

    HashMap 与 ConcurrentHashMap 原理总结

    2021年10月5日
    39
  • send,recv,sendto,recvfrom

    send,recv,sendto,recvfrom

    2021年12月15日
    45
  • webapi安全验证_手机测试路由器丢包率

    webapi安全验证_手机测试路由器丢包率无线局域网鉴别与保密基础结构WAPI是无线局域网安全协议,也被列为多种检测的测试项目。自联盟成员西电捷通研发WAPI技术以来,我们在密切跟踪WAPI安全技术的基础上,按照协议的技术特点将其工程实践化,而且,基于对WAPI安全协议的深刻理解,我们对WAPI安全协议的检测形成了一套系统方法,并研发了WAPI安全协议检测系统,如何保障WAPI安全协议检测系统测试的准确性和稳定性将是测试工作的核心。

    2022年10月15日
    0
  • 约瑟夫环问题链表实现(Java)

    约瑟夫环问题链表实现(Java)面试中可能经常会遇到约瑟夫环问题,逻辑上很简单,就是看怎么实现了,一般而言,最简单最直观的就是利用链表,然后构建一个循环结构,正好是环,最后计算出结果。遍历环形链表会是一个无限循环,如果链表中的数据逐渐减少,不控制终究会一个不剩,这又不满足我们问题的求解,因此我们需要定义出循环结束的条件,按照约瑟夫环的规则,只剩下一个的时候就结束,在环形链表结构中,那就是结点本身的下一个节点就…

    2022年6月4日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号