Существует ли безопасный способ надежно определить, может ли интегральный тип t сохранить целочисленное значение с плавающей точкой f (так что f == Пол (f) ) без какого-либо переполнения? Целое число переполнений - это не определено поведение в C ++. Я заинтересован в решении, которое является правильным в соответствии с текущим стандартом C ++ (C ++ 17 на написании) и избегает не определенного поведения .
Следующий наивный подход не является надежным, поскольку нет гарантии, что тип f может представлять std :: numeric_limits :: max () supating-point> nupe-point-point> wating-point-point>. />
#include
#include
#include
template
bool is_safe_conversion(F x)
{
static_assert(std::is_floating_point_v);
static_assert(std::is_integral_v);
// 'fmax' may have a different value than expected
static constexpr F fmax = static_cast(std::numeric_limits::max());
return std::abs(x)
есть идея? < /p>
Подробнее здесь: https://stackoverflow.com/questions/513 ... conversion
Надежное обнаружение переполнения конверсии с плавающей точкой/целочисленным типом ⇐ C++
Программы на C++. Форум разработчиков
1755753315
Anonymous
Существует ли безопасный способ надежно определить, может ли интегральный тип t сохранить целочисленное значение с плавающей точкой f (так что f == Пол (f) ) без какого-либо переполнения? Целое число переполнений - это не определено поведение в C ++. Я заинтересован в решении, которое является правильным в соответствии с текущим стандартом C ++ (C ++ 17 на написании) и избегает не определенного поведения .
Следующий наивный подход не является надежным, поскольку нет гарантии, что тип f может представлять std :: numeric_limits :: max () supating-point> nupe-point-point> wating-point-point>. />
#include
#include
#include
template
bool is_safe_conversion(F x)
{
static_assert(std::is_floating_point_v);
static_assert(std::is_integral_v);
// 'fmax' may have a different value than expected
static constexpr F fmax = static_cast(std::numeric_limits::max());
return std::abs(x)
есть идея? < /p>
Подробнее здесь: [url]https://stackoverflow.com/questions/51304323/reliable-overflow-detection-of-floating-point-integer-type-conversion[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия