delete []m_data

String::~String(void)
{
  delete [ ] m_data;  // 由于m_data 是内部数据类型,也可以写成 delete m_data;

}


这是为了与前面的new相对应
如果前面的new格式为char * a=new char[12];(注意,有[])
则后面delete就要有[];
如果前面new没有[],则后面delete也不需要有


int* p = new int;
那就调用delete p;

p = new int[10];
就调用 delete [] p;

不过由于int是内部类型,这里调用delete p也没有问题,编译器会帮你搞定。

----------------------------------------------------------------------------------

this is totally wrong.

已经用valgrind验证过,一定要写成delete [] p;的方式,不管p是什么数据类型

----------------------------------------------------------------------------------


如果是自定义类型就不可以了。
class MyClass
{
public:
     MyClass(){ printf("Construct\n");}
     ~MyClass(){ printf( "Destroy\n");}
};
MyClass* p = new MyClass[10];
delete p;

这个地方调用delete就有错了,编译器只能帮你析构p[0]。

所以对于new出来的自定义类型数组必须使用delete[]。


conclusion:

无论对于何种数据类型,都需要delete [] p;

如果new的时候有[],那么delete也有[]肯定是没问题的


### C++ 中 `DenseStorage` 拷贝构造函数初始化 `m_data` 在处理 `DenseStorage` 类型的拷贝构造函数时,如果遇到编译错误,通常是因为成员变量 `m_data` 的初始化存在问题。假设 `m_data` 是一个指针类型的成员变量用于指向动态分配的内存区域。 对于动态分配的资源管理,在C++中推荐使用智能指针来代替原始指针以减少潜在的风险并简化代码维护工作。然而,当实现自定义类如 `DenseStorage` 并手动管理内部数据结构时,则需要注意深浅复制的区别以及如何正确地释放已分配的资源[^1]。 #### 正确初始化 `m_data` 的方法 以下是通过显式的内存分配和赋值语句完成深层副本创建的一个例子: ```cpp class DenseStorage { private: double* m_data; size_t m_size; public: // 构造函数 explicit DenseStorage(size_t size) : m_size(size), m_data(new double[size]) {} // 拷贝构造函数 DenseStorage(const DenseStorage& other) : m_size(other.m_size), m_data(new double[m_size]) { // 分配新空间 std::copy(other.m_data, other.m_data + m_size, m_data); // 复制数据 } ~DenseStorage() { delete[] m_data; // 清理资源 } }; ``` 上述代码展示了如何安全有效地执行深层复制操作,从而避免了由于共享同一块堆上分配的数据而导致未定义行为的可能性。注意这里还实现了析构函数以便及时回收不再使用的内存资源。 此外,考虑到现代C++编程实践,建议尽可能利用RAII原则(Resource Acquisition Is Initialization),即让对象在其生命周期内自动负责获取和释放其所拥有的资源。这可以通过采用标准库容器或智能指针等方式达成更简洁可靠的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值