std::strcoll
来自cppreference.com
<tbody>
</tbody>
| 在标头 <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 相同的结果 (函数) | |
strcoll 的 C 文档
| |