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 является типом массива, предоставляет константу-член value равную количеству элементов вдоль N -го измерения массива, если N находится в диапазоне [ 0 , std:: rank < T > :: 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]
количество элементов вдоль N -го измерения T
(public static member constant)

Функции-члены

operator std::size_t
преобразует объект в std:: size_t , возвращает value
(public member function)
operator()
(C++14)
возвращает value
(public member function)

Типы-члены

Тип Определение
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> {};
**Примечание:** Весь код C++ внутри тегов `
` и `` оставлен без изменений, как и требовалось. HTML-разметка и атрибуты также сохранены в оригинальном виде.

Пример

#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]', поэтому размерность
    // не может быть корректно вычислена и возвращается 0
    static_assert(std::is_same_v<decltype(ary[0]), int(&)[3]>);
    static_assert(std::extent_v<decltype(ary[0])> == 0);
    // удаление ссылки дает корректное значение размера 3
    static_assert(std::extent_v<std::remove_cvref_t<decltype(ary[0])>> == 3);
}

Смотрите также

(C++11)
проверяет, является ли тип массивом
(шаблон класса)
(C++11)
получает количество измерений типа массива
(шаблон класса)
удаляет одно измерение из заданного типа массива
(шаблон класса)
удаляет все измерения из заданного типа массива
(шаблон класса)
(C++23)
дескриптор многомерного индексного пространства некоторого ранга
(шаблон класса)