Destructs object(s) previously allocated by the new expression and releases obtained memory area
For the first (non-array) form, Template:sparam must be a pointer or a class with a user-defined conversion function to a pointer, and its value must be either null or pointer to a non-array object created by a new-exression, or a pointer to a base subobject of a non-array object created by a new-exression (if it's anything else, the behavior is undefined).
If Template:sparam is not a null pointer, the
delete expression invokes the destructor (if any) for the object that's being destroyed, or for every element of the array being destroyed (proceeding from the last element to the first element of the array).
The deallocation function's name is firstly looked up in the local class type scope and only if the lookup fails, the global namespace is looked up. If
:: is present in the
delete expression, only the global namespace is looked up. The prototype of the function must look like the following:
Template:ddcl list begin <tr class="t-dcl "><td >
<td class="t-dcl-nopad"> </td> <td > for the first version </td> </tr> <tr class="t-dcl "><td >
<td class="t-dcl-nopad"> </td> <td > for the second version </td> </tr> Template:ddcl list end
Both these functions are implicitly declared in each translation unit. Also, implicit implementations are provided by the compiler by default, unless the program has explicitly implemented them. See this for more information.
If Template:sparam evaluates to a null pointer value, no destructors are called. The deallocation function may or may not be called (it's implementation-defined), but the default deallocation functions are guaranteed to do nothing when handed a null pointer.