реклама на сайте
подробности

 
 
> тонкости constexpr
esaulenka
сообщение Apr 21 2017, 12:01
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



Здравствуйте.
Возникла проблема после апгрейда gcc 4.8 на последнюю (6-ю) версию.

Есть у меня класс - драйвер таймера, в котором используемый таймер описан как
static constexpr TIM_TypeDef * const SYSTIMER = TIM6;
где TIM6 - стандартный дефайн ((TIM_TypeDef *) TIM6_BASE).

Раньше всё было хорошо, компилировалось-работало, а теперь поломалось:
начиная с какой-то версии gcc подкрутили, и в полном соответствии со стандартом reinterpret_cast стал неконстантным выражением.

Народ на стековерфлоу предлагает удалить constexpr.
Что-то мне эта идея не нравится - мне в основном надо просто прочитать значение этого таймера, и код этот раздувается вдвое.

Что б тут сделать?.. Обратно #define не хочу...


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Major
сообщение Apr 24 2017, 10:08
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 618
Регистрация: 7-12-04
Из: Новосибирск
Пользователь №: 1 375



Не ясно в чем проблема?
char x = 0;
auto p = reinterpret_cast<uintptr_t>(&x);
Без ругани сохранили указатель в p, явным приведением типа.

Покажите шаблон, возможно в нем проблема.

Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 06:44
Рейтинг@Mail.ru


Страница сгенерированна за 0.01354 секунд с 7
ELECTRONIX ©2004-2016