对 SFINAE 使用参数在 void_t 中的方法
using methods with parameter(s) in void_t for SFINAE
我正在尝试构建一个结构 is_container 以便在 SFINAE 模板上使用它
template<typename T, typename = void>
struct is_container : std::false_type {};
template<typename T>
struct is_container<
T,
std::void_t<
typename T::value_type,
typename T::reference,
typename T::const_reference,
typename T::iterator,
typename T::const_iterator,
typename T::difference_type,
typename T::size_type,
decltype(std::declval<T>().begin()),
decltype(std::declval<T>().end()),
decltype(std::declval<T>().cbegin()),
decltype(std::declval<T>().cend()) ,
decltype(std::declval<T>().size()),
decltype(std::declval<T>().max_size()),
decltype(std::declval<T>().empty()),
decltype(std::declval<T>().swap()) //<------ problem here
>
> : public std::true_type {};
template<typename T>
inline constexpr bool is_container_v = is_container<T>::value;
我的问题是交换函数采用 T& 参数,因此 static_assert(is_container_v>) 失败。他们是在我的 void_t 中使用带有参数的方法的方法吗?
您已经使用 declval
一次获取成员函数访问权限。所以再次使用它来获得左值参数。
decltype(std::declval<T>().swap(std::declval<T&>()))
我正在尝试构建一个结构 is_container 以便在 SFINAE 模板上使用它
template<typename T, typename = void>
struct is_container : std::false_type {};
template<typename T>
struct is_container<
T,
std::void_t<
typename T::value_type,
typename T::reference,
typename T::const_reference,
typename T::iterator,
typename T::const_iterator,
typename T::difference_type,
typename T::size_type,
decltype(std::declval<T>().begin()),
decltype(std::declval<T>().end()),
decltype(std::declval<T>().cbegin()),
decltype(std::declval<T>().cend()) ,
decltype(std::declval<T>().size()),
decltype(std::declval<T>().max_size()),
decltype(std::declval<T>().empty()),
decltype(std::declval<T>().swap()) //<------ problem here
>
> : public std::true_type {};
template<typename T>
inline constexpr bool is_container_v = is_container<T>::value;
我的问题是交换函数采用 T& 参数,因此 static_assert(is_container_v
您已经使用 declval
一次获取成员函数访问权限。所以再次使用它来获得左值参数。
decltype(std::declval<T>().swap(std::declval<T&>()))