dlf*_*dlf 3 c++ templates sfinae type-traits c++11
我想要的语义与std::remove_pointer真指针相似但可用于指针类的东西。我自然可以列举出已知的可能性:
// Important: remove_pointer_ex<T>::type should evaluate to T
// if T::operator* is not defined (like std::remove_pointer)
template<typename T> struct remove_pointer_ex { typedef T type; };
template<typename T> struct remove_pointer_ex<T*> { typedef T type; };
template<typename T> struct remove_pointer_ex<std::shared_ptr<T>> { typedef T type; };
template<typename T> struct remove_pointer_ex<std::unique_ptr<T>> { typedef T type; };
// and then again for all the different cv combinations
Run Code Online (Sandbox Code Playgroud)
但我真的很想一种可以与任何支持类一起使用的方法operator*。
看起来这应该可以使用SFINAE和/或类型特征来实现。这个问题的答案描述了如何测试特定类型是否具有特定成员,我想我可以结合使用这些建议之一enable_if,但是坦率地说,如果没有不那么丑陋的方法来解决问题,我宁愿只是尝试一种完全不同的方法。
使用默认为T但std::remove_reference<decltype(*T)>最好在有效时使用的类型特征(Live at Coliru):
template <typename T>
class remove_pointer_ {
template <typename U=T>
static auto test(int) -> std::remove_reference<decltype(*std::declval<U>())>;
static auto test(...) -> std::remove_cv<T>;
public:
using type = typename decltype(test(0))::type;
};
template <typename T>
using remove_pointer = typename remove_pointer_<T>::type;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
345 次 |
| 最近记录: |