相关疑难解决方法(0)

关于std::add_pointer的实现的一个问题

来自std::add_pointer

可能的实施

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。 …

c++ std

5
推荐指数
1
解决办法
309
查看次数

标签 统计

c++ ×1

std ×1