如何防止引用返回的私有结构的突变
How to prevent mutation of private structures returned by reference
我有以下代码:
struct MyStruct {
int a;
int b;
};
class Foo {
public:
MyStruct const &getValue() {
return value;
}
private:
MyStruct value{10, 20};
};
int main() {
Foo foo{};
auto v = foo.getValue();
v.a = 42; // compiles! it shouldn't!
}
我想返回对私有成员的引用,但不允许调用方更改此引用的内容。仅仅声明返回类型MyStruct const &
是不够的,因为它可能将引用本身定义为 const,而不是对象引用指向。但是,将返回类型声明为MyStruct& const
失败,并显示"'const' 限定符可能不会应用于引用"。我相信我可能在这里错过了一些东西。
我本可以通过声明所有 const 字段的MyStruct
来解决这个问题,但我想在我的类中自己改变它——只不允许调用者这样做。
怎么可能呢?
仅仅将返回类型声明为 MyStruct const 是不够的,因为它可能将引用本身定义为 const,而不是对象引用指向。
这是不对的。无论如何,都无法重新分配引用。这是返回对不可变对象的引用的正确方法。但是,您实际上复制了返回的对象:
auto v = foo.getValue();
然后修改副本,这是一个有效的操作。您可以将v
声明为参考
auto &v = foo.getValue();
获取预期的编译器错误。演示
你的错误假设是auto v
声明了一个引用。它没有,你会得到从getValue()
返回的MyStruct
的副本。
您可以检查原始对象是否未发生突变:
int main() {
Foo foo{};
auto v = foo.getValue();
v.a = 42; // compiles! it should!
std::cout << foo.getValue().a; //prints 10
}
将v
声明为引用类型不会编译
int main() {
Foo foo{};
auto& v = foo.getValue(); // const is deduced by auto
v.a = 42; // error
}
相关文章:
- 如何循环打印顶点结构
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 预处理器:插入结构名称中的前一个行号
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 孤立代码块在结构中引发异常
- 有什么方法可以遍历结构吗
- 如何在 C# 中映射双 C 结构指针?
- 如何在C++中使用结构生成映射
- 无法将结构注册为增强几何体3D点
- 多成员Constexpr结构初始化
- C++将文本文件中的数据读取到结构数组中
- 如何重构类层次结构以避免菱形问题
- 如何在C++中序列化结构数据
- std::vector的包装器,使数组的结构看起来像结构的数组
- 没有为自己的结构调用列表推回方法
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何防止引用返回的私有结构的突变
- 如何使用节俭C++ API 在 HBase 中存储字节数组(突变结构中的值是文本 ..)
- 将结构转换为类并使用构造函数、突变器和访问器