- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个看起来有点像这样的类:
class S
{
public:
int* data;
S() : data(new int[10]) {}
};
构造函数分配了 10 个整数的内存,默认的复制构造函数如预期的那样只复制指针本身而不是内容。
即使有 S
的实例具有 const
修饰符,我也可以修改 data
指向的数据,因为该数据本身没有 const
修饰符。我可以通过将 data
设为私有(private)并仅允许通过非 const
方法进行写访问来避免这种情况,如下所示:
class S
{
private:
int* data;
public:
S() : data(new int[10]) {}
int& operator(size_t i)
{
return data[i];
}
const int& operator(size_t i) const
{
return data[i];
}
};
但现在我可以使用复制构造函数来规避 S
实例的 const
特性,如下所示:
void main()
{
const S a; // Allocates memory
S b(a); // Also points to memory allocated for a
b(1) = 3; // Writes to a even though it is not supposed to be mutable
}
什么是解决这个问题的优雅方法(可能使用模板)?
const S
的实例指向的数据不应该仅使用该实例是可变的。const S
和 S
都应该可以通过复制构造函数创建,给定 S
的实例,这样 const
实例不能修改数据,但非 const
实例可以。最佳答案
通过提供两个不同的复制构造函数,可以在复制构造函数中知道被复制的对象是否为 const
,一个接受 const
参数,另一个接受不是。编译器将选择与传递的参数匹配的版本。在构造函数中设置一个标志,以便在执行非常量操作时抛出错误。
避免问题中显示的内存泄漏的最佳方法是使用像 std::shared_ptr
这样的智能指针而不是原始指针。不幸的是,shared_ptr
适用于单个对象,而不是数组;解决方法是可能的 as in this StackOverflow question .我现在不打算尝试解决这个问题,下面的代码仍然存在漏洞。
要完整,您应该遵循 Rule of Three并提供 operator=
和析构函数。我将此作为练习留给读者。
class S
{
private:
int* data;
bool is_const;
public:
S() : data(new int[10]), is_const(false) { data[1] = 42; }
S(const S& other) : data(other.data), is_const(true) {}
S(S& other) : data(other.data), is_const(false) {}
int& operator()(size_t i)
{
if (is_const)
throw std::logic_error("non-const operation attempted");
return data.ptr[i];
}
const int& operator()(size_t i) const
{
return data.ptr[i];
}
};
查看实际效果:http://ideone.com/SFN89M
关于c++ - const struct 的指针成员,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44163256/
我有一个数组 items[] items[] 中的每一项都是一个结构体。 item 有键 id、date、value(即 item.id、item.date、item.value) 我想使用 Stru
我想存储 100 名员工。 RollNo,姓名,工资,时间(各种数据,我无法在这里解释,但你可以看下面的代码片段来理解 main() { struct day { int hour
这个问题在这里已经有了答案: storage size of ‘names’ isn’t known (3 个答案) 关闭 5 年前。 我正在尝试蓝牙编程,遇到了这个我不明白的问题。基本上,当我使用
这是一个奇怪的事情: 我有一个结构,它包含指向相同类型结构的指针和指向其他类型结构的指针,以及一些其他值。 struct animal { struct animal * father;
我有一个结构定义如下(名称不同) struct str1 { int field1; struct str2; } 我在一个函数中有一个*str1。我想要一个指向 str2 的指针。 所以
DISK_DETECTION_INFO is defined as有什么原因吗? typedef struct _DISK_DETECTION_INFO { DWORD Size
我正在尝试打包一个字符串和一个字符串的长度。 fmt = '
我在创建结构时遇到问题。 我的结构: public struct Device: Codable { let data: DeviceData let meta: Meta? } pu
struct Item { var name:String? var type:String? var value:Int? var tag:Int? } ... ..
// NewReaderSize returns a new Reader whose buffer has at least the specified 43 // size. If the ar
这个问题在这里已经有了答案: Sorting a vector of custom objects (14 个答案) 关闭 3 年前。 在下面的 C++ 片段中, 如何基于 TwoInts 结构中的
#include struct Header { unsigned long long int alignment; }; int main(void) { struct Heade
我有一个目前看起来像这样的结构(缩写为仅显示基本部分): typedef struct { uint32_t baudrate; ... some other internally u
对此没有太多解释,这就是我所拥有的: public struct PACKET_HEADER { public string computerIp; publi
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
struct S1 { char c; int i; }; struct S3 { char c1; struct S1 s; double c2; }; 我正
我有一个名为 Parameter 的协议(protocol): protocol Parameter { var name: String { get } var unit: Unit
有 2 个 struct 定义 A 和 A。我知道 struct A 可以包含指向 struct A 的 POINTER 但我不明白为什么 struct A 不能包含struct A(不是指针) 最佳
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
为了说明这一点,这里有一个小的不可变结构和一个更新它的函数: (struct timeseries (variable observations) #:transparent) (define (ad
我是一名优秀的程序员,十分优秀!