инициализация constexpr с помощью указателей

Я пытаюсь инициализировать объявление constexpr с указателем на int, который является объектом const. Я также пытаюсь определить объект с помощью объекта, который не является константным типом.

Код:

#include <iostream>

int main()
{
constexpr int *np = nullptr; // np is a constant to int that points to null;
int j = 0;
constexpr int i = 42; // type of i is const int
constexpr const int *p = &i; // p is a constant pointer to the const int i;
constexpr int *p1 = &j; // p1 is a constant pointer to the int j;
}

Журнал g ++:

constexpr.cc:8:27: error: ‘& i’ is not a constant expression
constexpr.cc:9:22: error: ‘& j’ is not a constant expression

Я полагаю, что это потому, что объекты в main не имеют фиксированных адресов, поэтому g ++ возвращает мне сообщения об ошибках; как бы я исправить это? Без использования литеральных типов.

9

Решение

Сделать их static исправить их адреса:

int main()
{
constexpr int *np = nullptr; // np is a constant to int that points to null;
static int j = 0;
static constexpr int i = 42; // type of i is const int
constexpr const int *p = &i; // p is a constant pointer to the const int i;
constexpr int *p1 = &j; // p1 is a constant pointer to the int j;
}

Это известно как адресное выражение [5.19p3]:

Выражение константы адреса является основным значением константы
типа указателя, который оценивает адрес объекта со статическим
срок хранения, адрес функции или нулевой указатель
значение или постоянное выражение основной константы типа std :: nullptr_t.

13

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector