// Группировки описываются символьной строкой, но осмысленными
// являются числовые значения символов, а не собственно символы
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<T>::pattern
, который имеет член
field
типа
T[4]
, где
T
— символьный тип. Каждый элемент поля
field
содержит один из элементов перечисления
moneypunct<T>::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.)
use_facet<collate<char> >(locale); // Использовать глобальную
// локализацию
const char* pb1 = s1.data;
const char* pb2 = s2.data;
return (col.compare(pb1, pb1 + s1.size,
pb2, pb2 + s2.size) < 0);
}
int main (
// Создать две строки, одна с немецким символом
string s1 = "diät";
string s2 = "dich";
vector<string> v;
v.push_back(s1);
v.push_back(s2);
// Сортировать, не используя заданную локализацию, т.е. Применяя
// правила текущей глобальной локализации
sort(v.begin, v.end);
for (vector<string>::const_iterator p = v.begin;
p != v.end; ++p)
cout << *p << endl;
// Установить в качестве глобальной немецкую локализацию и затем
// сортировать
locale::global(locale("german"));
sort(v.begin, v.end, localelessThan);
for (vector<string>::const_iterator p = v.begin;
p != v.end; ++p)
cout << *p << endl;
}
Первый вариант обеспечивает сортировку по коду ASCII, и поэтому результат будет выглядеть следующим образом.
dich
diät
Вторая сортировка использует правильный порядок букв немецкого алфавита, и поэтому результат будет противоположным.
diät
dich
Обсуждение
Сортировка усложняется, когда вы работаете с различными локализациями, но стандартная библиотека решает эту проблему. Фасет
collate
обеспечивает функцию-член
compare
, которая работает как
strcmp
: она возвращает значение -1, если первая строка меньше второй, значение 0, если они равны, и значение 1, если первая строка больше второй. В отличие от
strcmp
, функция
collate::compare
использует определенную в целевой локализации упорядоченность символов.