Namespaces
Variants

std:: extent

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, unsigned N = 0 >
struct extent ;
(C++11 起)

如果 T 是数组类型,且 N [ 0 , std:: rank < T > :: value ) 范围内,则提供等于数组第 N th 维元素数量的成员常量 value 。对于任何其他类型,或者当 T 是第一维为未知边界的数组且 N 0 时, value 0

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

目录

辅助变量模板

template < class T, unsigned N = 0 >
constexpr std:: size_t extent_v = extent < T, N > :: value ;
(C++17 起)

继承自 std:: integral_constant

成员常量

value
[static]
T 类型第 N 维的元素数量
(公开静态成员常量)

成员函数

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, unsigned N = 0>
struct extent : std::integral_constant<std::size_t, 0> {};
template<class T>
struct extent<T[], 0> : std::integral_constant<std::size_t, 0> {};
template<class T, unsigned N>
struct extent<T[], N> : std::extent<T, N - 1> {};
template<class T, std::size_t I>
struct extent<T[I], 0> : std::integral_constant<std::size_t, I> {};
template<class T, std::size_t I, unsigned N>
struct extent<T[I], N> : std::extent<T, N - 1> {};

示例

#include <type_traits>
static_assert(
    std::extent_v<int[3]> == 3 && // 默认维度为 0
    std::extent_v<int[3], 0> == 3 && // 同上
    std::extent_v<int[3][4], 0> == 3 &&
    std::extent_v<int[3][4], 1> == 4 &&
    std::extent_v<int[3][4], 2> == 0 &&
    std::extent_v<int[]> == 0
);
int main()
{
    const auto ext = std::extent<int['*']>{};
    static_assert(ext == 42); // 通过隐式转换为 std::size_t
    const int ints[]{1, 2, 3, 4};
    static_assert(std::extent_v<decltype(ints)> == 4); // 数组大小
    [[maybe_unused]] int ary[][3] = {{1, 2, 3}};
    // ary[0] 的类型是 'int[3]' 的引用,因此无法正确计算 extent,返回 0
    static_assert(std::is_same_v<decltype(ary[0]), int(&)[3]>);
    static_assert(std::extent_v<decltype(ary[0])> == 0);
    // 移除引用后得到正确的 extent 值 3
    static_assert(std::extent_v<std::remove_cvref_t<decltype(ary[0])>> == 3);
}

参见

(C++11)
检查类型是否为数组类型
(类模板)
(C++11)
获取数组类型的维度数量
(类模板)
从给定数组类型移除一个维度
(类模板)
从给定数组类型移除所有维度
(类模板)
(C++23)
多维索引空间的描述符
(类模板)