博客
关于我
C++ 友元
阅读量:714 次
发布时间:2019-03-21

本文共 1121 字,大约阅读时间需要 3 分钟。

在软件工程中,友元(friend)是允许外部代码访问一个类或函数非公有的成员的机制。通过声明友元,开发者可以突破封装性,实现灵活的代码访问控制。

友元的作用

友元机制为函数和类提供了访问类外部成员的途径,使得代码可以在需要时实现更强大的交互能力。

友元的限制

友元declaring类的封装性一定程度上被破坏,虽然这种限制可以灵活满足需求,但也带来代码维护的复杂性。

友元函数示例

class Test {private:    int m_data;public:    Test(int data): m_data(data) {}    ~Test() {}    friend void show(Test& t);};void show(Test& t) {    std::cout << "t.m_data = " << t.m_data << std::endl;    return;}int main() {    Test t(123);    show(t);    return 0;}

友元类示例

class Test {private:    int m_data;public:    Test(int data): m_data(data) {}    ~Test() {}    friend class Brother;};class Brother {public:    Brother() {}    ~Brother() {}    friend class Son;    void show(Test& t) {        std::cout << "t.m_data = " << t.m_data << std::endl;        return;    }};class Son: public Father {public:    Son() {}    ~Son() {}    void show(Test& t) {        std::cout << "Son data = " << t.m_data << std::endl;        return;    }};int main() {    Test t(123);    Brother b;    b.show(t);    return 0;}

友元类的关系

友元类具有以下性质:

  • 不能继承:父亲的朋友不是你的朋友。
  • 不能传递:朋友的朋友不是你的朋友。
  • 不能反转:你的友元不是你的朋友的友元。

友元关系具有不可逆性和不可传递性,这部层次性的规则设计确保了类的继承关系不会因友元关系而产生混乱。

转载地址:http://olbrz.baihongyu.com/

你可能感兴趣的文章
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
查看>>
Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
查看>>
NCNN中的模型量化解决方案:源码阅读和原理解析
查看>>
NCNN源码学习(1):Mat详解
查看>>
nc命令详解
查看>>