Namespaces
Variants

std::pointer_safety

From cppreference.com
 
 
Memory management library
(exposition only*)
Allocators
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Memory resources
Uninitialized storage (until C++20)
(until C++20*)
(until C++20*)

Garbage collector support (until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
Low level memory
management
    
(C++17)
Smart pointers
(C++11)
(C++11)
(C++11)
(until C++17*)
(C++11)
(C++26)
(C++23)
Miscellaneous
(C++20)
(C++11)
(C++11)
C Library
(C++26)
 
Defined in header <memory>
enum class pointer_safety {
     relaxed,
     preferred,
     strict
};
(since C++11)
(removed in C++23)

The scoped enumeration type pointer_safety lists the pointer safety modes supported by C++.

Enumeration constants

Enumerator Meaning
pointer_safety::strict Only safely-derived pointers (pointers to objects allocated with new or subobjects thereof) may be dereferenced or deallocated. Garbage collector may be active.
pointer_safety::preferred All pointers are considered valid and may be dereferenced or deallocated. A reachability-based leak detector may be active.
pointer_safety::relaxed All pointers are considered valid and may be dereferenced or deallocated.

See also

(C++11)(removed in C++23)
returns the current pointer safety model
(function) [edit]