Namespaces
Variants

std:: tolower

From cppreference.net
定义于头文件 <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> 使用本地环境的 ctype 刻面将字符转换为小写形式
(函数模板)
将字符转换为大写形式
(函数)
将宽字符转换为小写形式
(函数)
C 文档 关于 tolower

外部链接

1. ISO/IEC 8859-1 . 来自维基百科。
2. ISO/IEC 8859-15 . 来自维基百科。