int field2 = from_string(matches[2]);

  int field3 = from_string(matches[3]);

  // ...

}

Синтаксис регулярных выражений основан на символах, имеющих особый смысл (см. главу 23).

Некоторые классы символов поддерживаются аббревиатурами.

<p id="AutBody_Root681"><strong>Б.9. Численные методы</strong></p>

В стандартной библиотеке языка C++ содержатся основные строительные конструкции для математических (научных, инженерных и т.д.) вычислений.

<p id="AutBody_Root682"><strong>Б.9.1. Предельные значения</strong></p>

Каждая реализация языка C++ определяет свойства встроенных типов, чтобы программисты могли использовать эти средства для проверки предельных значений, установки предохранителей и т.д.

В заголовке определен класс numeric_limits для каждого встроенного или библиотечного типа T. Кроме того, программист может определить класс numeric_limits для пользовательского числового типа X. Рассмотрим пример.

class numeric_limits {

public:

  static const bool is_specialized = true;

  static const int radix = 2;    // основание системы счисления

                                 // (в данном случае двоичная)

  static const int digits = 24;  // количество цифр в мантиссе

                                 // в текущей системе счисления

  static const int digits10 = 6; // количество десятичных цифр

                                 // в мантиссе

  static const bool is_signed = true;

  static const bool is_integer = false;

  static const bool is_exact = false;

  static float min() { return 1.17549435E–38F; } // пример

  static float max() { return 3.40282347E+38F; } // пример

  static float epsilon() { return 1.19209290E–07F; } // пример

  static float round_error() { return 0.5F; }        // пример

  static float infinity() { return /* какое-то значение */; }

  static float quiet_NaN() { return /* какое-то значение */; }

  static float signaling_NaN() { return /* какое-то значение */; }

  static float denorm_min() { return min(); }

  static const int min_exponent = –125;  // пример

  static const int min_exponent10 = –37; // пример

  static const int max_exponent = +128;  // пример

  static const int max_exponent10 = +38; // пример

  static const bool has_infinity = true;

  static const bool has_quiet_NaN = true;

  static const bool has_signaling_NaN = true;

  static const float_denorm_style has_denorm = denorm_absent;

  static const bool has_denorm_loss = false;

  static const bool is_iec559 = true; // соответствует системе IEC-559

  static const bool is_bounded = true;

  static const bool is_modulo = false;

  static const bool traps = true;

  static const bool tinyness_before = true;

  static const float_round_style round_style =

                                 round_to_nearest;

};

В заголовках и определены макросы, определяющие основные свойства целых чисел и чисел с плавающей точкой.

<p id="AutBody_Root683"><strong>Б.9.2. Стандартные математические функции</strong></p>

В стандартной библиотеке определены основные математические функции (в заголовках и ).

Существуют версии этих функций, принимающие аргументы типа float, double, long double и complex. У каждой из этих функций тип возвращаемого значения совпадает с типом аргумента.

Если стандартная математическая функция не может выдать корректный с математической точки зрения результат, она устанавливает переменную errno.

<p id="AutBody_Root684"><strong>Б.9.3. Комплексные числа</strong></p>
Перейти на страницу:
Нет соединения с сервером, попробуйте зайти чуть позже