友元不是破坏封装,而是封装机制的精细调节阀;它在严格控制下为可信协作者提供有限访问权限,用于无法通过公有接口高效实现的场景,如流操作符重载。

友元不是破坏封装,而是在严格控制的前提下,为特定需求提供有限的访问权限。它不违背封装原则,而是封装机制的一部分——封装的目标是隐藏实现细节、保护数据安全,而不是把所有东西都锁死。友元恰恰是在“谁可以看”“看到多少”上做了精准授权。
当某个操作逻辑上不属于类的职责,但又必须读写其私有数据时(比如重载输入输出流),用成员函数反而会污染类接口。这时友元函数就派上用场。
适用于两个类存在紧密协作关系,且这种关系是设计上明确、稳定、受控的。例如容器类与它的迭代器类、工厂类与被创建的具体类。
友元不是后门,而是经过设计评审的“授权通道”。是否该用,关键看三点:
立即学习“C++免费学习笔记(深入)”;
实现一个自定义字符串类 MyString,想支持 std::cout 输出:
class MyString {
char* data_;
size_t len_;
public:
MyString(const char* s) : len_(s ? strlen(s) : 0), data_(new char[len_+1]) {
if (s) strcpy(data_, s);
}
~MyString() { delete[] data_; }
<pre class="brush:php;toolbar:false;">// 友元函数:不属类,但需读私有成员
friend std::ostream& operator<<(std::ostream& os, const MyString& s) {
return os << (s.data_ ? s.data_ : "");
}};
这里不用成员函数,因为 operator 左操作数是 std::ostream,无法改成成员;也不该暴露 data_ 给所有人——只授权给这个特定的流输出函数即可。
基本上就这些。友元不是封装的漏洞,而是封装的精细调节阀。用得准,它让接口更干净、性能更优、协作更自然;用得滥,才真成隐患。关键不在“能不能用”,而在“为什么非用不可”。
以上就是c++++中的友元(friend)函数和类有什么用_c++破坏封装的正确姿势【详解】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号