2013-04-17 4 views
19

Как вопрос, который пришел во время обсуждения this SO question:Является ли законным объявление объекта constexpr initializer_list?

Законно ли это, может быть, с N3471, чтобы объявить constexpr std::initializer_list объект? Пример:

constexpr std::initializer_list<int> my_list{}; 

Почему я думаю, что это не может быть законным: initializer_list должен быть буквальным типа; но есть ли какие-либо гарантии, что это буквальный тип?

Цитаты из N3485.

[dcl.constexpr]/9:

constexpr спецификатор используется в объявлении объекта объявляет объект константным. Такой объект должен иметь тип и должен быть инициализирован.

буквенные требования типов, [basic.types]/10, к югу от пулевых типов классов:

  • тип класса (пункт 9), который имеет все из следующих свойств:
    • У него есть тривиальный деструктор,
    • каждый вызов конструктора и полное выражение в элементарных элементах для нестатических данных (если есть) является константным выражением (5.19),
    • это совокупный тип (8.5.1) или имеет хотя бы один конструктор конструктора или конструктора constexpr, который не является конструктором копирования или перемещения, и
    • все его нестатические элементы данных и базовые классы не являются -устойчивые типы литералов.

Бонусные баллы;) за ответы, если

constexpr std::initializer_list<int> my_list = {1,2,3,4,5}; 

является законным (со ссылками). Хотя я думаю, что это охватывается выше + [dcl.init.list]/5

+0

Просто повторить то, что я сказал в чате: на самом деле я не собираюсь создавать 'std :: initializer_list' функции' constexpr' (N3741), если мы не можем законно записать последний пример. – Morwenn

ответ

8

Update: Ситуация стала немного более сложным, после разрешения CWG DR 1684 отменила требование цитируемом ниже. Некоторые более подробную информацию можно найти в this discussion on the std-discussion mailing list и в связанный с этим вопрос Why isn't `std::initializer_list` defined as a literal type?


[decl.constexpr]/8:

constexpr спецификатор для не-статической функции-члена, который не является конструктором объявляет, что функция-член является константой (9.3.1). [...] Класс, членом которого является член, должен быть буквальный тип (3.9).

Таким образом, изменения гарантии N3471 std::initializer_list будут буквальными.


Обратите внимание на constexpr т е р в одиночку не требует std::initializer_list быть буквальным типа, см [dcl.constexpr]/4 + 8. Примечание стороны: Объект небуквального типа с constexpr CTOR может быть инициализировано во время инициализации постоянной [basic.start.init]/2] (часть статической инициализации, выполняемой перед любым динамической инициализации).

+0

Я нашел этот ответ спустя несколько часов после публикации вопроса - интересно, какое использование будет 'constexpr' ctor в нелитеральном типе. – dyp

+0

Я не уверен, что все понимаю - это 'constexpr std :: initializer_list my_list = {1,2,3,4,5};' legal или нет в C++ 14? – ChristopherC

+0

@ChristopherC Извините, похоже, для этого требуется новое расследование: разрешение [CWG DR 1684] (http://open-std.org/jtc1/sc22/wg21/docs/cwg_defects.html#1684) удалило цитируемый отрывок из стандарта C++ 14. Я не могу найти никаких других намеков, что 'std :: initializer_list' должен быть буквальным типом на данный момент. – dyp

Смежные вопросы