名前空間
変種
操作

std::wcscoll

From cppreference.com
< cpp‎ | string‎ | wide
 
 
 
 
ヘッダ <cwchar> で定義
int wcscoll( const wchar_t* lhs, const wchar_t* rhs );

ロケールで最後にインストールされた std::setlocale による、LC_COLLATE カテゴリで定義されるロケールに従って、2つのヌル終端ワイド文字列を比較します。

目次

[編集] パラメータ

lhs, rhs - 比較するヌル終端ワイド文字列へのポインタ

[編集] 返り値

lhsrhs より *小さい* (先行する) 場合、負の値。

0 If lhs is *equal to* rhs.

lhsrhs より *大きい* (後続する) 場合、正の値。

[編集] 注記

照合順序は辞書順です。つまり、文字の国立アルファベットでの位置 (その *同値クラス*) が、大文字/小文字やバリアントよりも優先されます。同値クラス内では、小文字が対応する大文字よりも前に照合され、ダイアクリティカルマーク付きの文字にはロケール固有の順序が適用される場合があります。一部のロケールでは、文字のグループが単一の *照合単位* として比較されます。たとえば、チェコ語の "ch""h" の後に、"i" の前に来ます。ハンガリー語の "dzs""dz" の後に、"g" の前に来ます。

[編集]

#include <clocale>
#include <iostream>
 
void try_compare(const wchar_t* p1, const wchar_t* p2)
{
    if (std::wcscoll(p1, p2) < 0)
        std::wcout << p1 << " before " << p2 << '\n';
    else
        std::wcout << p2 << " before " << p1 << '\n';
}
 
int main()
{
    std::setlocale(LC_ALL, "en_US.utf8");
    std::wcout << "In the American locale: ";
    try_compare(L"hrnec", L"chrt");
 
    std::setlocale(LC_COLLATE, "cs_CZ.utf8");
    std::wcout << "In the Czech locale: ";
    try_compare(L"hrnec", L"chrt");
 
    std::setlocale(LC_COLLATE, "en_US.utf8");
    std::wcout << "In the American locale: ";
    try_compare(L"år", L"ängel");
 
    std::setlocale(LC_COLLATE, "sv_SE.utf8");
    std::wcout << "In the Swedish locale: ";
    try_compare(L"år", L"ängel");
}

出力

In the American locale: chrt before hrnec
In the Czech locale: hrnec before chrt
In the American locale: ängel before år
In the Swedish locale: år before ängel

[編集] 関連項目

現在のロケールに従って2つの文字列を比較する
(関数) [編集]
[virtual]
このファセットの照合規則を使用して2つの文字列を比較します。
(std::collate<CharT> の仮想保護メンバー関数) [編集]
wcscmpwcscollと同じ結果を生成するようにワイド文字列を変換する
(関数) [編集]
English 日本語 中文(简体) 中文(繁體)