Namespaces
Variants

std:: rank

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定义于头文件 <type_traits>
template < class T >
struct rank ;
(C++11 起)

如果 T 是数组类型,提供成员常量 value 等于数组的维度数。对于其他任何类型, value 0

如果程序为 std::rank std::rank_v (C++17 起) 添加特化,则行为未定义。

目录

辅助变量模板

template < class T >
constexpr std:: size_t rank_v = rank < T > :: value ;
(自 C++17 起)

继承自 std:: integral_constant

成员常量

value
[static]
T 的维度数量或零
(公开静态成员常量)

成员函数

operator std::size_t
将对象转换为 std:: size_t ,返回 value
(公开成员函数)
operator()
(C++14)
返回 value
(公开成员函数)

成员类型

类型 定义
value_type std:: size_t
type std:: integral_constant < std:: size_t , value >

可能的实现

template<class T>
struct rank : public std::integral_constant<std::size_t, 0> {};
template<class T>
struct rank<T[]> : public std::integral_constant<std::size_t, rank<T>::value + 1> {};
template<class T, std::size_t N>
struct rank<T[N]> : public std::integral_constant<std::size_t, rank<T>::value + 1> {};

示例

#include <type_traits>
static_assert(std::rank<int>{} == 0);
static_assert(std::rank<int[5]>{} == 1);
static_assert(std::rank<int[5][5]>{} == 2);
static_assert(std::rank<int[][5][5]>{} == 3);
int main()
{
    [[maybe_unused]] int ary[][3] = {{1, 2, 3}};
    // 引用类型(如 ary[0],即 int(&)[3])的秩为 0:
    static_assert(std::rank_v<decltype(ary[0])> == 0);
    static_assert(std::is_same_v<decltype(ary[0]), int(&)[3]>);
    // 解决方案是移除引用类型。
    static_assert(std::rank_v<std::remove_cvref_t<decltype(ary[0])>> == 1);
}

参见

(C++11)
检查类型是否为数组类型
(类模板)
(C++11)
获取数组类型在指定维度上的大小
(类模板)
从给定数组类型移除一个维度
(类模板)
从给定数组类型移除所有维度
(类模板)