34 #ifndef _GLIBCXX_EXPERIMENTAL_MEMORY
35 #define _GLIBCXX_EXPERIMENTAL_MEMORY 1
37 #pragma GCC system_header
39 #if __cplusplus >= 201402L
47 namespace std _GLIBCXX_VISIBILITY(default)
49 _GLIBCXX_BEGIN_NAMESPACE_VERSION
51 namespace experimental
53 inline namespace fundamentals_v2
55 #define __cpp_lib_experimental_observer_ptr 201411
57 template <
typename _Tp>
62 using element_type = _Tp;
63 using __pointer = add_pointer_t<_Tp>;
64 using __reference = add_lvalue_reference_t<_Tp>;
68 constexpr observer_ptr() noexcept
73 constexpr observer_ptr(nullptr_t) noexcept
77 constexpr
explicit observer_ptr(__pointer __p) noexcept
82 template <
typename _Up,
83 typename =
typename enable_if<
84 is_convertible<typename add_pointer<_Up>::type, __pointer
87 constexpr observer_ptr(observer_ptr<_Up> __p) noexcept
106 operator->() const noexcept
111 constexpr
explicit operator bool() const noexcept
113 return get() !=
nullptr;
117 constexpr
explicit operator __pointer() const noexcept
126 __pointer __tmp = get();
132 reset(__pointer __p =
nullptr) noexcept
138 swap(observer_ptr& __p) noexcept
147 template<
typename _Tp>
149 swap(observer_ptr<_Tp>& __p1, observer_ptr<_Tp>& __p2) noexcept
154 template<
typename _Tp>
156 make_observer(_Tp* __p) noexcept
158 return observer_ptr<_Tp>(__p);
161 template<
typename _Tp,
typename _Up>
163 operator==(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
165 return __p1.get() == __p2.get();
168 template<
typename _Tp,
typename _Up>
170 operator!=(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
172 return !(__p1 == __p2);
175 template<
typename _Tp>
177 operator==(observer_ptr<_Tp> __p, nullptr_t) noexcept
182 template<
typename _Tp>
184 operator==(nullptr_t, observer_ptr<_Tp> __p) noexcept
189 template<
typename _Tp>
191 operator!=(observer_ptr<_Tp> __p, nullptr_t) noexcept
196 template<
typename _Tp>
198 operator!=(nullptr_t, observer_ptr<_Tp> __p) noexcept
203 template<
typename _Tp,
typename _Up>
205 operator<(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
208 typename add_pointer<_Up>::type
210 >{}(__p1.get(), __p2.get());
213 template<
typename _Tp,
typename _Up>
215 operator>(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
220 template<
typename _Tp,
typename _Up>
222 operator<=(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
224 return !(__p2 < __p1);
227 template<
typename _Tp,
typename _Up>
229 operator>=(observer_ptr<_Tp> __p1, observer_ptr<_Up> __p2)
231 return !(__p1 < __p2);
236 template <
typename _Tp>
237 struct hash<experimental::observer_ptr<_Tp>>
239 using result_type = size_t;
240 using argument_type = experimental::observer_ptr<_Tp>;
243 operator()(
const experimental::observer_ptr<_Tp>& __t)
const
244 noexcept(noexcept(hash<
typename add_pointer<_Tp>::type> {}(__t.get())))
246 return hash<typename add_pointer<_Tp>::type> {}(__t.get());
251 _GLIBCXX_END_NAMESPACE_VERSION
constexpr complex< _Tp > operator*(const complex< _Tp > &__x, const complex< _Tp > &__y)
Return new complex value x times y.
void swap(any &__x, any &__y) noexcept
Exchange the states of two any objects.
ISO C++ entities toplevel namespace is std.
One of the comparison functors.