Пространства имён
Варианты
Действия

std::is_aggregate

Материал из cppreference.com
 
 
Библиотека метапрограммирования
Свойства типов
Категории типов
(C++11)
(C++14)  
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Свойства типов
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(до C++20*)
(C++11)(устарело в C++20)
(C++11)
Константы свойств типа
Метафункции
(C++17)
Поддерживаемые операции
Запросы отношений и свойств
Модификации типов
(C++11)(C++11)(C++11)
Преобразования типов
(C++11)(устарело в C++23)
(C++11)(устарело в C++23)
(C++11)
(C++11)
(C++17)

(C++11)(до C++20*)(C++17)
Рациональна�� арифметика времени компиляции
Целочисленные последовательности времени компиляции
 
<tbody> </tbody>
Определено в заголовочном файле <type_traits>
template< class T > struct is_aggregate;
(начиная с C++17)

std::is_aggregate является UnaryTypeTrait.

Если T является агрегатным типом, предоставляет константу-элемент value, равную true. Для любого другого типа value равна false.

Если T является неполным типом, отличным от типа массива или (возможно, cv-квалифицированным) void, поведение не определено.

Поведение программы, добавляющей специализации для std::is_aggregate или std::is_aggregate_v не определено.

Параметры шаблона

T тип для проверки

Шаблон вспомогательной переменной

<tbody> </tbody>
template< class T > inline constexpr bool is_aggregate_v = is_aggregate<T>::value;
(начиная с C++17)

Унаследован от std::integral_constant

Константы элементы

value
[static]
true, если T агрегатный тип, false иначе
(public static константа-элемент)

Функции-элементы

operator bool
преобразует объект в bool, возвращает value
(public функция-элемент)
operator()
(C++14)
возвращает value
(public функция-элемент)

Типы элементы

Тип Определение
value_type bool
type std::integral_constant<bool, value>

Примечание

Макрос Тестирования функциональности Значение Стандарт Функциональность
__cpp_lib_is_aggregate 201703L (C++17) std::is_agregate

Пример

#include <new>
#include <type_traits>
#include <utility>

// строит T в неинициализированной памяти, на которую указывает p, используя
// инициализацию списком для агрегатов и инициализацию не списком иначе
template<class T, class... Args>
T* construct(T* p, Args&&... args)
{
    if constexpr(std::is_aggregate_v<T>)
    {
        return ::new (static_cast<void*>(p)) T{std::forward<Args>(args)...};
    }
    else
    {
        return ::new (static_cast<void*>(p)) T(std::forward<Args>(args)...);
    }
}

struct A { int x, y; };
struct B { B(int, const char*) { } };

int main()
{
    std::aligned_union_t<1, A, B> storage;
    [[maybe_unused]] A* a = construct(reinterpret_cast<A*>(&storage), 1, 2);
    [[maybe_unused]] B* b = construct(reinterpret_cast<B*>(&storage), 1, "привет");
}

Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 3823 C++17 Поведение не определено, если T является типом массива, а
std::remove_all_extents_t<T> является неполным типом.
Поведение определяется независимо от
неполноты std::remove_all_extents_t<T>, если T
является типом массива.