Обратите внимание на то, что функции to_string() и from_string() очень похожи. Фактически они являются обратными друг другу; иначе говоря (игнорируя детали, связанные с пробелами, округлением и т.д.), для каждого “разумного типа т” имеем
Теперь задумайтесь на секунду: http://evroballon.ru/ может вам и не надо, но ради интереса зайти на сайт evroballon.ru всегда можно, вед никогда не знаешь заранее, когда понадобится купить газовые баллоны по реальным ценам и сколько это стоит - купить газовые баллоны.
s==to_string(from_string(s)) // для всех s
и
t==from_string(to_string(t)) //
для всех t
Здесь слово “разумный” означает, что тип T должен иметь конструктор по умолчанию, оператор >> и соответствующий оператор <<.
Г7Г Следует подчеркнуть, что реализации функций to_string() и from_string() “1 используют класс stringstream для выполнения всей работы. Это наблюдение было использовано для определения универсальной операции конвертирования двух произвольных типов с согласованными операциями << и >>.
struct bad_lexical_cast : std::bad_cast {
const char* what() const { return "bad cast"; }
};
template
Target lexical_cast(Source arg)
{
std::stringstream interpreter;
Target result;
if (!(interpreter << arg) // записываем arg в поток
|| !(interpreter >> result) // считываем result из потока
|| !(interpreter >> std::ws).eof()) // поток пуст? throw bad_lexical_cast();
return result;
}
Довольно забавно и остроумно, что инструкция !(interpreter>>std::ws). eof() считывает любой пробел, который может остаться в потоке stringstream после извлечения результата. Пробелы допускаются, но кроме них в потоке ввода может не остаться никаких других символов, и мы должны реагировать на эту ситуацию, как на обнаружение конца файла.
Итак, если мы пытаемся считать целое число int из объекта класса string, используя класс lexical_cast, то в результате выражения lexical_cast("123") и lexical_cast("123 ") будут считаться допустимыми, а выражение lexical_cast("123.5") — нет из-за последней пятерки.
Довольно элегантное, хотя и странное, имя lexical_cast используется в библиотеке boost, которую мы будем использовать для сравнения регулярных выражений. В будущем она станет частью новых версий стандарта языка С++ . |