名前空間
変種
操作

std::strcoll

提供: cppreference.com
< cpp‎ | string‎ | byte
ヘッダ <cstring> で定義
int strcoll(constchar* lhs, constchar* rhs );

LC_COLLATE カテゴリで定義されている現在のロケールに従って、2つのヌル終端バイト文字列を比較します。

目次

[編集]引数

lhs, rhs - 比較するヌル終端バイト文字列を指すポインタ

[編集]戻り値

lhsrhs より小さい (前に来る) 場合は負の値。

lhsrhs等しい場合は 0

lhsrhs より大きい (後に来る) 場合は正の値。

[編集]ノート

照合順序は辞書順です。 アルファベットの文字 (等価クラス) の位置は大文字小文字や変種よりも高い優先度を持ちます。 等価クラス内では、小文字は同等な大文字よりも前に照合され、ダイアクリティカルマーク付きの文字にはロケール固有の順序が適用されるかもしれません。 ロケールによっては、文字のグループが単一の照合単位として比較されます。 例えば、チェコ語の "ch""h" より後、 "i" より前に、ハンガリー語の "dzs""dz" より後、 "g" より前に来ます。

[編集]

#include <iostream>#include <cstring>#include <clocale>   int main(){std::setlocale(LC_COLLATE, "cs_CZ.iso88592");   constchar* s1 ="hrnec";constchar* s2 ="chrt";   std::cout<<"In the Czech locale: ";if(std::strcoll(s1, s2)<0)std::cout<< s1 <<" before "<< s2 <<'\n';elsestd::cout<< s2 <<" before "<< s1 <<'\n';   std::cout<<"In lexicographical comparison: ";if(std::strcmp(s1, s2)<0)std::cout<< s1 <<" before "<< s2 <<'\n';elsestd::cout<< s2 <<" before "<< s1 <<'\n';}

出力:

In the Czech locale: hrnec before chrt In lexicographical comparison: chrt before hrnec

[編集]関連項目

現在のロケールに従って2つのワイド文字列を比較します
(関数)[edit]
[仮想]
このファセットの照合ルールを用いて2つの文字列を比較します
(std::collate<CharT>の仮想プロテクテッドメンバ関数)[edit]
strcoll と同じ結果を strcmp で得られるように文字列を変換します
(関数)[edit]
close