Пространства имён
Варианты
Действия

std::locale::operator()

Материал из cppreference.com
< cpp‎ | locale‎ | locale
 
 
Локализация
Локали и фасеты
locale
Классификация символов
Преобразования
Базовые классы фасетов
Категории фасетов
Зависящие от локали категории фасетов
Не зависящие от локали фасеты преобразования юникода
codecvt_utf8(C++11)
codecvt_utf16(C++11)
Локали С
 
std::locale
Член типов
Оригинал:
Member types
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
locale::id
locale::facet
Член функций
Оригинал:
Member functions
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
locale::locale
locale::~locale
locale::operator=
locale::combine
locale::name
locale::operator==
locale::operator!=
locale::operator()
Статические функции-члены
Оригинал:
Static member functions
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
locale::global
locale::classic
 
template< class CharT, class Traits, class Alloc >

bool operator()( const basic_string<CharT,Traits,Alloc>& s1,

                 const basic_string<CharT,Traits,Alloc>& s2) const;

Сравнивает два строковых аргумента s1 и s2 в соответствии с лексикографическими правилами сравнения, определяемыми фасетом std::collate<charT> этой локали. Этот оператор может использоваться любым объектом локали, имеющим фасет из категории сортировки строк, который будет использоваться как бинарный предикат в стандартных алгоритмах (таких, как std::sort) и упорядоченных контейнерах (вроде std::set).

Содержание

[править] Параметры

s1 - первая строка для сравнения
s2 - вторая строка для сравнения

[править] Возвращаемое значение

true, если строка s1 лексикографически меньше строки s2, и false в противном случае.

[править] Возможная реализация

template<class CharT, class Traits, class Alloc >
bool operator()(const std::basic_string<CharT,Traits,Alloc>& s1,
                const std::basic_string<CharT,Traits,Alloc>& s2) const;
{
    return std::use_facet<std::collate<GharT>>(*this).compare(
                                         s1.data(), s1.data() + s1.size(),
                                         s2.data(), s2.data() + s2.size()   ) < 0;
}

[править] Пример

При помощи объекта локали в качестве компаратора вектор строк может быть отсортирован в соответствии с нестандартной локалью:

#include <locale>
#include <algorithm>
#include <vector>
#include <string>
#include <cassert>
 
int main()
{
    std::vector<std::wstring> v = {L"жил", L"был", L"кот"};
    std::sort(v.begin(), v.end(), std::locale("ru_RU.UTF8"));
    assert(v[0] == L"был");
    assert(v[1] == L"жил");
    assert(v[2] == L"кот");
}


[править] Смотрите также

определяет лексикографическое сравнение и правила хэширования строк
(шаблон класса) [править]