【发布时间】:2012-07-20 06:49:24
【问题描述】:
我有一个简单的课程:
class Histogram {
int m_width;
int m_height;
int m_sampleSize;
int m_bufferWidth;
int m_bufferHeight;
uint8* m_buffer;
int m_size;
public:
Histogram() : m_buffer(0) { }
Histogram(int width, int height, int sampleSize) {
m_buffer = new unsigned char [width*height*sampleSize];
}
~Histogram() {
my_log("destructor: buffer: %p", m_buffer);
if ( m_buffer ) { delete [] m_buffer; m_buffer = NULL; }
}
unsigned char* buffer() {
return m_buffer;
}
};
它是其他类的成员:
class Other {
Histogram m_histogram;
void reset() {
my_log("reset() called: buffer: %p", m_histogram.buffer());
m_histogram = Histogram(512, 512, 2);
}
}
现在,我首先使用 Histogram() 构造函数创建“未初始化”对象——它将 m_buffer 设置为 NULL;
然后,我调用 reset 方法,它执行 m_histogram = Histogram( 512, 512, 3 ) - 新对象已通过 new 初始化 m_buffer。
所以预期的日志消息顺序是:
- "reset() 调用:缓冲区:0x0"
- “析构函数:缓冲区:0x0”
但相反,我得到:
- "reset() 调用:缓冲区:0x0"
- “析构函数:缓冲区:0x072a7de”
因此正在执行一些不合理的操作。此外,当我还删除第二个对象(使用“更大”构造函数创建,具有三个 int 参数)时,会显示 0x072a7de 地址。
【问题讨论】:
-
编译器生成的默认复制构造函数和赋值运算符不能很好地处理指针。您需要遵守
rule of three(或 C++11 中的五个)参见:stackoverflow.com/a/255744/14065
标签: c++ constructor copy-constructor