|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Defined in header <wchar.h> | ||
int wcscoll(constwchar_t*lhs,constwchar_t*rhs); | (since C95) | |
Compares two null-terminated wide strings according to the collation order defined by theLC_COLLATE category of the currently installed locale.
Contents |
| lhs, rhs | - | pointers to the null-terminated wide strings to compare |
Negative value iflhs isless than (precedes)rhs.
0 iflhs isequal torhs.
Positive value iflhs isgreater than (follows)rhs.
Collation order is the dictionary order: the position of the letter in the national alphabet (itsequivalence class) has higher priority than its case or variant. Within an equivalence class, lowercase characters collate before their uppercase equivalents and locale-specific order may apply to the characters with diacritics. In some locales, groups of characters compare as singlecollation units. For example,"ch" in Czech follows"h" and precedes"i", and"dzs" in Hungarian follows"dz" and precedes"g".
#include <stdio.h>#include <wchar.h>#include <locale.h> void try_compare(constwchar_t* p1,constwchar_t* p2){if(wcscoll(p1, p2)<0)printf("%ls before %ls\n", p1, p2);elseprintf("%ls before %ls\n", p2, p1);} int main(void){setlocale(LC_ALL,"en_US.utf8");printf("In the American locale: "); try_compare(L"hrnec", L"chrt"); setlocale(LC_COLLATE,"cs_CZ.utf8");printf("In the Czech locale: "); try_compare(L"hrnec", L"chrt"); setlocale(LC_COLLATE,"en_US.utf8");printf("In the American locale: "); try_compare(L"år", L"ängel"); setlocale(LC_COLLATE,"sv_SE.utf8");printf("In the Swedish locale: "); try_compare(L"år", L"ängel");}
Possible output:
In the American locale: chrt before hrnecIn the Czech locale: hrnec before chrtIn the American locale: ängel before årIn the Swedish locale: år before ängel
| compares two strings in accordance to the current locale (function)[edit] | |
(C95) | transform a wide string so thatwcscmp would produce the same result aswcscoll (function)[edit] |
(C95) | compares two wide strings (function)[edit] |
C++ documentation forwcscoll | |