Отладка исключения SIGFPE [закрыто]C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Отладка исключения SIGFPE [закрыто]

Сообщение 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);


Подробнее здесь: https://stackoverflow.com/questions/793 ... -exception
Ответить

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

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

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

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

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