std:: tolower
|
定义于头文件
<cctype>
|
||
|
int
tolower
(
int
ch
)
;
|
||
根据当前安装的C语言区域设置定义的字符转换规则,将给定字符转换为小写形式。
在默认的
"C"
区域设置中,以下大写字母
ABCDEFGHIJKLMNOPQRSTUVWXYZ
会被替换为对应的小写字母
abcdefghijklmnopqrstuvwxyz
。
目录 |
参数
| ch | - | 待转换的字符。若 ch 的值无法表示为 unsigned char 且不等于 EOF ,则行为未定义 |
返回值
ch 的小写版本,若当前 C 区域设置中未列出对应小写形式则返回未修改的 ch 。
注释
与
<cctype>
中的所有其他函数类似,若参数值既不能表示为
unsigned
char
也不等于
EOF
,则
std::tolower
的行为是未定义的。要安全地将这些函数用于普通
char
(或
signed
char
),应首先将参数转换为
unsigned
char
:
char my_tolower(char ch) { return static_cast<char>(std::tolower(static_cast<unsigned char>(ch))); }
同样地,当迭代器的值类型为 char 或 signed char 时,不应直接将其与标准算法一起使用。而应先将值转换为 unsigned char :
std::string str_tolower(std::string s) { std::transform(s.begin(), s.end(), s.begin(), // static_cast<int(*)(int)>(std::tolower) // 错误 // [](int c){ return std::tolower(c); } // 错误 // [](char c){ return std::tolower(c); } // 错误 [](unsigned char c){ return std::tolower(c); } // 正确 ); return s; }
示例
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\xb4'; // ISO-8859-15 中的字符 Ž // 但在 ISO-8859-1 中是 ´(锐音符) std::setlocale(LC_ALL, "en_US.iso88591"); std::cout << std::hex << std::showbase; std::cout << "in iso8859-1, tolower('0xb4') gives " << std::tolower(c) << '\n'; std::setlocale(LC_ALL, "en_US.iso885915"); std::cout << "in iso8859-15, tolower('0xb4') gives " << std::tolower(c) << '\n'; }
可能的输出:
in iso8859-1, tolower('0xb4') gives 0xb4
in iso8859-15, tolower('0xb4') gives 0xb8
参见
|
将字符转换为大写形式
(函数) |
|
| td> 使用本地环境的 | |
|
将宽字符转换为小写形式
(函数) |
|
|
C 文档
关于
tolower
|
|
外部链接
| 1. | ISO/IEC 8859-1 . 来自维基百科。 |
| 2. | ISO/IEC 8859-15 . 来自维基百科。 |