Я работаю над большим проектом, мы переходим на gcc12 и обновляем версию boost. В одном из тестовых случаев мы видим SIGFPE (Linux), добавленный в следующий код повышения.
Здесь T — long double, а Char имеет тип char. Любые предложения будут оценены.
template
inline static bool add(T& n, Char ch, mpl::true_) // checked add
{
// Ensure n *= Radix will not overflow
T const max = (std::numeric_limits::max)();
T const val = max / Radix;
if (n > val)
return false;
T tmp = n * Radix; //tmp = 0
// Ensure n += digit will not overflow
const int digit = radix_traits::digit(ch); //digit = 4
if (tmp > max - digit) //This line is throwing SIGFPE.
return false;
n = tmp + static_cast(digit);
return true;
}
};
Есть ли случай, когда следующий фрагмент кода может вызвать исключение SIGFPE. Согласно отладчику (gdb), условие «if» выдает SIGFPE
long double maxVal = (std::numeric_limits::max)();
int digit = 4;
long double tmpVal = 0; //0 value is result of some calculation and not constant
if(tmpVal > maxVal - digit) //can this line throw SIGFPE.
{
//do something.
}
Здесь long double имеет размер 16 байт, поэтому это должно быть число с плавающей запятой IEEE128.
Код построен с использованием gcc12 в Linux. Код повышения (версия 1.81), который мы используем, приведен ниже:
std::vector v;
r = phrase_parse(startIter, last,
// Begin grammar
(
qi::long_double[push_back(phoenix::ref(v), _1)] % -qi::lit(',')
)
,
// End grammar
boost::spirit::ascii::space_type);
Подробнее здесь: https://stackoverflow.com/questions/793 ... -exception
Отладка исключения SIGFPE [закрыто] ⇐ C++
Программы на C++. Форум разработчиков
1736395192
Anonymous
Я работаю над большим проектом, мы переходим на gcc12 и обновляем версию boost. В одном из тестовых случаев мы видим SIGFPE (Linux), добавленный в следующий код повышения.
Здесь T — long double, а Char имеет тип char. Любые предложения будут оценены.
template
inline static bool add(T& n, Char ch, mpl::true_) // checked add
{
// Ensure n *= Radix will not overflow
T const max = (std::numeric_limits::max)();
T const val = max / Radix;
if (n > val)
return false;
T tmp = n * Radix; //tmp = 0
// Ensure n += digit will not overflow
const int digit = radix_traits::digit(ch); //digit = 4
if (tmp > max - digit) //This line is throwing SIGFPE.
return false;
n = tmp + static_cast(digit);
return true;
}
};
Есть ли случай, когда следующий фрагмент кода может вызвать исключение SIGFPE. Согласно отладчику (gdb), условие «if» выдает SIGFPE
long double maxVal = (std::numeric_limits::max)();
int digit = 4;
long double tmpVal = 0; //0 value is result of some calculation and not constant
if(tmpVal > maxVal - digit) //can this line throw SIGFPE.
{
//do something.
}
Здесь long double имеет размер 16 байт, поэтому это должно быть число с плавающей запятой IEEE128.
Код построен с использованием gcc12 в Linux. Код повышения (версия 1.81), который мы используем, приведен ниже:
std::vector v;
r = phrase_parse(startIter, last,
// Begin grammar
(
qi::long_double[push_back(phoenix::ref(v), _1)] % -qi::lit(',')
)
,
// End grammar
boost::spirit::ascii::space_type);
Подробнее здесь: [url]https://stackoverflow.com/questions/79336045/debugging-sigfpe-exception[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия