博客
关于我
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/

你可能感兴趣的文章
ORA-01034: ORACLE not available
查看>>
ORA-01152: 文件 1 没有从过旧的备份中还原
查看>>
ORA-01207:文件比控制文件更新 - 旧的控制文件
查看>>
ORA-01795: 列表中的最大表达式数为 1000
查看>>
ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
查看>>
ORA-08102的错误
查看>>
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
查看>>
ORA-12514: TNS:listener does not currently know of service问题原因
查看>>
ora-12541:tns:no listener
查看>>
【docker知识】联合文件系统(unionFS)原理
查看>>
ORACEL学习--理解over()函数
查看>>
ORAchk-数据库健康检查
查看>>
oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
查看>>
Oracle 10g ORA-01034: ORACLE not available 错误
查看>>
oracle 10g的安装配置
查看>>
Oracle 11.2.0.4 x64 RAC修改public/private/vip/scan地址
查看>>
Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析
查看>>
viewpage listview gridview加载本地大图多图OOM处理办法
查看>>
Oracle 11g UNDO表空间备份增强
查看>>
Oracle 11g 使用RMAN备份数据库
查看>>