在realloc之后使用原始指针?

我正在阅读Richard Reese的新书(2013年5月)O’Reilly的书“理解和使用C指针”,我对其中的一些代码有疑问,第87页。

if (++length > maximumLength) { char *newBuffer = realloc (buffer, maximumLength += sizeIncrement); if (newBuffer == NULL) { free (buffer); return NULL; } currentPosition = newBuffer + (currentPosition - buffer); buffer = newBuffer; } 

我希望变量的名称是不言自明的; 如果需要上下文,我将编辑以提供整个代码块而不仅仅是这个摘录。

我的问题是关于行currentPosition = newBuffer + (currentPosition - buffer); 。 我对realloc()理解是,当新分配成功时,最初分配的内存被释放。 如果这是正确的,那么有问题的线是使用悬空指针,不是吗? 该表达式的RHS上的buffercurrentPosition都是指向已释放的内存的指针。

我的直觉是重写这个以避免使用悬挂指针通过使用length ,毕竟已经存在。 我想用以下代码替换最后两行:

 buffer = newBuffer; currentPosition = buffer + length; 

但是,大概写入的代码是有效的,因为两个指针仍然保存地址(尽管是垃圾),并且这两个地址之间的偏移仍然可以作为重新分配currentPosition的方式来计算。 那么我是否只是对此感到不安?

概括问题:一旦指针悬空,为了任何目的使用指针中包含的地址是否安全,例如计算偏移量? 谢谢。

一旦指针悬空,是否可以安全地使用指针中包含的地址用于任何目的,例如计算偏移量?

不,这不安全。 free后指针值是无效地址,无效地址不能用于指针算术而不调用未定义的行为。

只要不尝试取消引用指针(即应用运算符*),使用悬空指针(例如“指针运算”)是安全的。