可能的实施
namespace detail {
template <class T>
struct type_identity { using type = T; }; // or use std::type_identity (since C++20)
template <class T>
auto try_add_pointer(int) -> type_identity<typename std::remove_reference<T>::type*>;
template <class T>
auto try_add_pointer(...) -> type_identity<T>;
} // namespace detail
template <class T>
struct add_pointer : decltype(detail::try_add_pointer<T>(0)) {};
Run Code Online (Sandbox Code Playgroud)
上述(可能的)实现的描述如下:
如果 T 是引用类型,则提供成员 typedef type,它是指向引用类型的指针。
否则,如果 T 命名对象类型、非 cv 或 ref 限定的函数类型或(可能是 cv 限定的)void 类型,则提供类型 T* 的成员 typedef 类型。
否则(如果 T 是 cv 或 ref 限定的函数类型),则提供成员 typedef type,它是类型 T。 …