解释:
std::rank仅适用于 c 样式数组。
所以我为 std::vector
实现了类似的 rank
,效果很好:
#include <iostream>
#include <vector>
template<typename Type, Type val>
struct integral_constant
{
static constexpr Type value =val;
};
template<typename>
struct rank
: public integral_constant<std::size_t, 0> { };
template<typename Type>
struct rank< std::vector<Type> >
: public integral_constant<std::size_t, 1 + rank<Type>::value> { };
template<class T>
constexpr size_t vector_dimentions(T)
{
return rank<T>::value ;
}
int main()
{
std::vector<std::vector<std::vector<int>>> vec;
std::cout<<vector_dimentions(vec) << '\n';
}
问题:
现在我想将它推广到其他容器,如 std::list
,...
所以我将结构定义更改为:
template<template<typename>class Container,typename Type>
struct rank< Container<Type> >
: public integral_constant<std::size_t, 1 + rank<Type>::value> { };
但是现在它给出了错误的答案(总是 0)!
我认为在这种情况下它无法推断出正确的结构,因为它现在有 2 个模板参数。这是对的吗 ?!我该如何解决?
最佳答案
在 KerrekSB 的帮助下我找到了解决方案:
template <typename> struct prank : std::integral_constant<std::size_t, 0> {};
template <template <typename...> class C, typename ...Args>
struct prank<C<Args...>>
: std::integral_constant<
std::size_t,
1 + prank<typename C<Args...>::value_type>::value> {};
template <typename U, typename V>
struct prank<std::pair<U, V>>
: std::integral_constant<std::size_t, 1 + prank<V>::value> {};
template <typename... Args>
struct prank<std::tuple<Args...>>
: std::integral_constant<std::size_t, 1> {};
template <typename T,typename... Args>
struct prank<std::tuple<T,Args...>>
: std::integral_constant<std::size_t, prank<T>::value+prank<std::tuple<Args...>>::value> {};
关于c++ - 为其他容器实现 std::rank,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24222427/