Д. Стефенс - C++. Сборник рецептов
- Название:C++. Сборник рецептов
- Автор:
- Жанр:
- Издательство:КУДИЦ-ПРЕСС
- Год:2007
- Город:Москва
- ISBN:5-91136-030-6
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Д. Стефенс - C++. Сборник рецептов краткое содержание
Данная книга написана экспертами по C++ и содержит готовые рецепты решения каждодневных задач для программистов на С++. Один из авторов является создателем библиотеки Boost Iostreams и нескольких других библиотек C++ с открытым исходным кодом. В книге затрагивается множество тем, вот лишь некоторые из них: работа с датой и временем; потоковый ввод/вывод; обработка исключений; работа с классами и объектами; сборка приложений; синтаксический анализ XML-документов; программирование математических задач. Читатель сможет использовать готовые решения, а сэкономленное время и усилия направить на решение конкретных задач.
C++. Сборник рецептов - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Все параметры money_put::put
не требуют дополнительных пояснений, кроме, возможно, второго (аргумент intl
в примере). Он имеет тип bool
и показывает, будет использоваться символ валюты (например, $, €) или трехбуквенное международное обозначение валюты (например, USD, EUR). Для использования символа валюты установите его в значение false
, а для использования международного обозначения валюты — в значение true
.
При записи денежных значений в поток вывода можно задавать некоторые параметры потока, которые управляют форматированием. Ниже описывается каждый параметр и объясняется его воздействие на вывод денежного значения.
ios_base::internal
Если при форматировании денежного значения задается пробел или пустое значение, будет использован символ заполнителя (а не пробел). Ниже при обсуждении moneypunct
приводятся дополнительные сведения по шаблонам форматирования.
ios_base::left
и ios_base::right
Выравнивает денежное значение влево или вправо; при этом остальные позиции в пределах заданной ширины заполняются символом заполнителя (см. описание следующего параметра, width
). Это удобно, потому что облегчает табуляцию денежного значения.
ios_base::width
Значения, выдаваемые функцией money_put
, подчиняются стандартным правилам управления шириной поля потока. По умолчанию эти значения выравниваются влево. Если поле больше, чем размер значения, используется символ заполнителя, указанный при вызове функции money_put
.
ios_base::showbase
Если этот флаг имеет значение «истина», символ валюты выводится, в противном случае он не выводится.
Как я говорил ранее, функции money_get
и money_put
используют класс moneypunct
, в котором фактически хранится информация о форматировании. Вам не стоит беспокоиться о классе moneypunct
, если вы не заняты реализацией стандартной библиотеки, но вы можете использовать его для исследования параметров форматирования, применяемых в конкретной локализации, moneypunct
содержит такие сведения, как используемый символ валюты, символ, используемый в качестве десятичной точки, формат положительных и отрицательных значений и т.д. В примере 13.7 представлена короткая программа, печатающая информацию о формате денежных значений, который используется в заданной локализации.
Пример 13.7. Вывод информации о форматировании денежных значений
#include
#include
#include
using namespace std;
string printPattern(moneypunct::pattern& pat) {
string s(pat.field); // pat.field имеет тип char[4]
string r;
for (int i = 0; i < 4; ++i) {
switch (s[i]) {
case moneypunct::sign:
r += "sign ";
break;
case moneypunct::none:
r += "none ";
break;
case moneypunct::space:
r += "space ";
break;
case moneypunct::value:
r += "value ";
break:
case moneypunct::symbol:
r += "symbol ";
break;
}
}
return(r);
}
int main() {
locale loc("danish");
const moneypunct& punct =
use_facet >(loc),
cout << "Decimal point: " << punct.decimal_point() << '\n'
<< "Thousands separator. " << punct.thousands_sep() << '\n'
<< "Currency symbol: " << punct.curr_symbol() << '\n'
<< "Positive sign: " << punct.positive_sign() << '\n'
<< "Negative sign: " << punct.negative_sign() << '\n'
<< "Fractional digits: " << punct.frac_digits() << '\n'
<< "Positive format: "
<< printPattern(punct pos_format()) << '\n'
<< "Negative format: "
<< printPattern(punct.neg_format()) << '\n';
// Группировки описываются символьной строкой, но осмысленными
// являются числовые значения символов, а не собственно символы
string s = punct.grouping();
for (string::iterator p = s.begin(); p != s.end(); ++p)
cout << "Groups of: " << (int)*p << '\n';
}
Назначение большинства этих методов самоочевидно, но некоторые методы требуют дополнительных пояснений. Во-первых, метод grouping
возвращает строку символов, которая интерпретируется как строка целочисленных значений. Каждый символ описывает свою группу цифр в числе, начиная с правой стороны числа. И если в какой-то позиции строки нет значения, то используется значение в предыдущей позиции. Другими словами, для стандартного американского формата в позиции 0 этой строки будет значение 3, что означает три цифры для группы с индексом 0. Поскольку других значений нет, все группы с индексом, большим нуля, должны также состоять из трех цифр.
pos_format
и neg_format
возвращают объект типа moneypunct::pattern
, который имеет член field
типа T[4]
, где T
— символьный тип. Каждый элемент поля field
содержит один из элементов перечисления moneypunct::part
, который имеет пять возможных значений: none
, space
, symbol
, sign
и value
. Строковое представление денежного значения состоит из четырех частей (т.е. массив с четырьмя элементами) Обычно части денежного значения образуют последовательность symbol space sign value
(символ валюты пробел знак значение), что означало бы вывод, например, значения $ -32.00. Часто знак плюс заменяется пустой строкой, поскольку значение без знака обычно рассматривается как положительное значение. Признак отрицательного числа может содержать несколько символов, как, например, « ()
», и в этом случае первый символ выдается в части symbol
формата отрицательного числа ( neg_format
), а другой символ выдается в конце, поэтому отрицательные числа могут иметь, например, такой вид: $(32.00).
Большую часть времени вам не придется беспокоиться по поводу получения информации о форматировании, содержащейся в moneypunct
. Однако если вам необходимо выполнить большой объем формирования денежных значений в различных локализациях, то имеет смысл поэкспериментировать и познакомиться с особенностями форматирования в различных локализациях.
Рецепты 13.2 и 13.3.
13.5. Сортировка локализованных строк
Имеется последовательность строк, содержащая символы не в коде ASCII, и требуется ее отсортировать с учетом местных особенностей.
В класс локализации встроена поддержка операций сравнения символов в заданной локализации путем перегрузки оператора operator<
. При вызове любой стандартной функции, принимающей функтор сравнения, можно использовать в качестве такого функтора экземпляр класса локализации. (См. пример 13.8.)
Пример 13.8. Сортировка с учетом местных особенностей
#include
#include
#include
#include
#include
using namespace std;
bool localelessThan(const string& s1, const string& s2) {
const collate& col =
use_facet >(locale()); // Использовать глобальную
Интервал:
Закладка: