description | title | ms.date | ms.topic | f1_keywords | helpviewer_keywords | ms.assetid | ||
---|---|---|---|---|---|---|---|---|
Learn more about: C26404 DONT_DELETE_INVALID |
C26404 |
07/21/2017 |
conceptual |
|
|
94afb700-3f3b-40db-8afc-2481935360c2 |
Once owner pointer releases or transfers its resource, it gets into an "invalid" state. Deleting such a pointer may lead to immediate memory corruption due to double delete, or to an access violation when the deleted resource is accessed from another owner pointer.
gsl::owner<State*> validState = nullptr;
gsl::owner<State*> state = ReadState();
validState = state;
if (!IsValid(state))
delete state; // C26404
gsl::owner<Message*> message;
if (popLast)
message = ReleaseMessage();
delete message; // C26404