在cpp 中定义了连个指针:
DATA* m_pdata = NULL;
DATA* m_pCopydata = NULL;
m_pCopydata 是m_pdata的一份拷贝,在其他地方用。
给m_pdata 申请空间:
void AllocSpace()
{
int m_count = 0;
int ncount = m_count + 100;
m_count= ncount ;
m_pdata = (DATA*)realloc(m_pdata , ncount*sizeof(DATA));
}
在第一次申请空间时:m_pCopydata = m_pdata ;
m_pCopydata 指向与m_pdata 相同的内存空间,在后面的调用中使用m_pCopydata 。
在一定的条件后重新申请空间:
if(m_count >= 100)
{
AllocSpace();
}
这时候我并没有将m_pdata 赋给m_pCopydata ,结果在使用m_pCopydata引起了crash.
查阅资料。发现原因是这样的:
先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域(注意:原来指针是自动释放,不需要使用free),同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。
所以,当没有连续内存空间时,realloc会返回一个新地址。并且释放掉原来的内存空间,这个时候我的m_pCopydata 和 m_pdata 值不一样了,所以要将m_pdata 的值重新赋给m_pCopydata 。即这样写:
if(m_count >= 100)
{
AllocSpace();
if(m_pCopydata != m_pdata )
{
m_pCopydata = m_pdata ;
}
}