std::strcoll
来自cppreference.com
在标头 <cstring> 定义
|
||
int strcoll( const char* lhs, const char* rhs ); |
||
按照 LC_COLLATE 类别所定义的当前本地环境,比较两个空终止字节字符串。
参数
lhs, rhs | - | 指向要比较的空终止字节字符串的指针 |
返回值
若 lhs 小于(前趋)rhs 则为负值。 若 lhs 等于 rhs 则为 0。 若 lhs 大于(后随)rhs 则为负值。
注解
校排顺序为字典顺序:国家字母表(其等价类)中字母的位置拥有高于其大小写或变体的优先级。在等价类内,小写字符先于其大写等价物校排,而且对有变音符的字符可能应用特定于本地环境的顺序。一些本地环境中,字符组作为单个校排单元参与比较。例如,"ch" 在捷克语中后随 "h" 而前趋 "i","dzs" 在匈牙利语中后随 "dz" 而前趋 "g"。
示例
运行此代码
#include <clocale> #include <cstring> #include <iostream> int main() { std::setlocale(LC_COLLATE, "cs_CZ.utf8"); // 作为替代,一些 OS 上 ISO-8859-2 (又称 Latin-2) 可能也能工作: // std::setlocale(LC_COLLATE, "cs_CZ.iso88592"); const char* s1 = "hrnec"; const char* s2 = "chrt"; std::cout << "捷克本地环境中: "; if (std::strcoll(s1, s2) < 0) std::cout << s1 << " 前驱 " << s2 << '\n'; else std::cout << s2 << " 前驱 " << s1 << '\n'; std::cout << "字典序比较中: "; if (std::strcmp(s1, s2) < 0) std::cout << s1 << " 前驱 " << s2 << '\n'; else std::cout << s2 << " 前驱 " << s1 << '\n'; }
输出:
捷克本地环境中: hrnec 前驱 chrt 字典序比较中: chrt 前驱 hrnec
参阅
按照当前本地环境比较两个宽字符串 (函数) | |
[虚] |
用此刻面的校排规则比较两个字符串 ( std::collate<CharT> 的虚受保护成员函数) |
变换字符串,使得 strcmp 会返回与 strcoll 相同的结果 (函数) |