指针是否保证在 C++ 中的“删除"之后保留其值?

Is the pointer guaranteed to preserve its value after `delete` in C++?(指针是否保证在 C++ 中的“删除之后保留其值?)
本文介绍了指针是否保证在 C++ 中的“删除"之后保留其值?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

灵感来自这个问题.

假设在 C++ 代码中我有一个有效的指针并正确地删除它.根据 C++ 标准,指针将变为无效(3.7.3.2/4 - 释放函数将使指向释放存储的所有部分的所有指针无效).

Suppose in C++ code I have a valid pointer and properly delete it. According to C++ standard, the pointer will become invalid (3.7.3.2/4 - the deallocation function will render invalid all pointers referring to all parts of deallocated storage).

至少在大多数实现中,它会保留该值,并将存储与 delete 之前完全相同的地址,但是 使用该值是未定义的行为.

At least in most implementations it preserves the value and will store exactly the same address as before delete, however using the value is undefined behavior.

标准是否保证指针将保留其值或允许值更改?

Does the standard guarantee that the pointer will preserve its value or is the value allowed to change?

推荐答案

不,不能保证,实现可以合法地将零分配给 lvalue 操作数以delete.

No, it's not guaranteed and an implementation may legitimately assign zero to an lvalue operand to delete.

Bjarne Stroustrup 曾希望实现会选择这样做,但不是很多.

Bjarne Stroustrup had hoped that implementations would choose to do this, but not many do.

http://www.stroustrup.com/bs_faq2.html#delete-zero

这篇关于指针是否保证在 C++ 中的“删除"之后保留其值?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Could I ever want to access the address zero?(我可以想访问地址零吗?)
C++ Access derived class member from base class pointer(C++ 从基类指针访问派生类成员)
Weird Behaviour with const_cast(const_cast 的奇怪行为)
Are pointer variables just integers with some operators or are they quot;symbolicquot;?(指针变量只是带有某些运算符的整数还是“符号?)
Modifying a char *const string(修改 char *const 字符串)
Modifying a const int in C++(修改 C++ 中的 const int)