GCC и Clang ведут себя по-разному в отношении постоянной оценки.C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 GCC и Clang ведут себя по-разному в отношении постоянной оценки.

Сообщение Anonymous »


Я наблюдаю несоответствие между GCC и Clang в отношении того, что такое константный оцениваемый контекст. Я играл с разными ситуациями:

#include #include consteval auto ceval(auto x) { return x * x; } constexpr auto constexrif (авто x) { if constexpr (std::is_integral_v) { вернуть Цеваль (х); } еще { вернуть х + 2.; } } constexpr auto constexprif_consteval (авто x) { if constexpr (std::is_integral_v) { если констеваль { вернуть Цеваль (х); } еще { вернуть х * х + 1; } } еще { вернуть х + 2.; } } constexpr auto constevalif (авто x) { если констеваль { вернуть Цеваль (х); } еще { return static_cast(x + 2.); } } constexpr auto isconstantevaluated(auto x) { если (std::is_constant_evaluated()) { вернуть Цеваль (х); } еще { return static_cast(x + 2.); } } интервал основной() { #ifdef __clang__ // GCC нокаут авто а = consexprif(42); const auto b = consexprif(42); constexpr auto c = constexrif(42); std::cout
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»