std::strcoll - cppreference.com
提供: cppreference.com
<tbody> </tbody>
|
|
||
LC_COLLATE カテゴリで定義されている現在のロケールに従って、2つのヌル終端バイト文字列を比較します。
引数
| lhs, rhs | - | 比較するヌル終端バイト文字列を指すポインタ |
戻り値
lhs が rhs より小さい (前に来る) 場合は負の値。
lhs が rhs と等しい場合は 0。
lhs が rhs より大きい (後に来る) 場合は正の値。
ノート
照合順序は辞書順です。 アルファベットの文字 (等価クラス) の位置は大文字小文字や変種よりも高い優先度を持ちます。 等価クラス内では、小文字は同等な大文字よりも前に照合され、ダイアクリティカルマーク付きの文字にはロケール固有の順序が適用されるかもしれません。 ロケールによっては、文字のグループが単一の照合単位として比較されます。 例えば、チェコ語の "ch" は "h" より後、 "i" より前に、ハンガリー語の "dzs" は "dz" より後、 "g" より前に来ます。
例
#include <iostream> #include <cstring> #include <clocale> int main() { std::setlocale(LC_COLLATE, "cs_CZ.iso88592"); const char* s1 = "hrnec"; const char* s2 = "chrt"; std::cout << "In the Czech locale: "; if(std::strcoll(s1, s2) < 0) std::cout << s1 << " before " << s2 << '\n'; else std::cout << s2 << " before " << s1 << '\n'; std::cout << "In lexicographical comparison: "; if(std::strcmp(s1, s2) < 0) std::cout << s1 << " before " << s2 << '\n'; else std::cout << s2 << " before " << s1 << '\n'; }
出力:
In the Czech locale: hrnec before chrt In lexicographical comparison: chrt before hrnec