其实不能算原创,实际上是我碰到问题后在参考别人的博客总结的。多少也花费了自己一些时间,不谦虚的加了个原创。想参考原帖可以忽略我的内容了,先给出参考地址:http://coolshell.cn/articles/9543.html。
可能用惯C的人喜欢使用数组来存放类对象。数组中每个元素的类型都是一样的。但是如果数组碰到了多态会怎么样?
第一种,使用指针数组;
第二种,使用基类指针指向一个派生类对象数组。
先上测试代码:
class TestClassBase
{
public:
TestClassBase(){}
virtual ~TestClassBase()
{
}
private:
};
class TestClassDerived : public TestClassBase
{
public:
TestClassDerived(){}
~TestClassDerived()
{
}
};
对第一种情况的说明,创建一个基类指针数组TestClassBase** pBase = new TestClassBase*[2],然后对它赋值,附上代码
TestClassBase** pBase = new TestClassBase*[2];
pBase[0] = new TestClassBase();
pBase[1] = new TestClassDerived();
这个指针数组的释放相信大家都比较熟悉了,遍历数组删除指针,然后再删除数组。
for (int i = 0; i < 2; i++)
{
delete pBase[i];
pBase[i] = NULL;
}
delete[] pBase;
这个都没有疑问,现在看下第二种情况:
TestClassBase* pB2 = new TestClassDerived[2];
delete[] pB2;
这样是否合适呢?我使用VC测试和g++测试都是通过的。但是那篇文章提到的一个问题就是当内存对齐,就是当sizeof(TestClassBase)和sizeof(TestClassDerived)不等的情况。在派生类中加入成员变量int i,然后重新测试,使用VC测试通过,使用g++报段错误。我对C底层了解不深,具体原理请参考原博客,在此就不赘述了。