命名空间
变体
操作

std::tolower

来自 cppreference.cn
< cpp‎ | string‎ | byte
定义于头文件 <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)));
}

同样,当迭代器的值类型为 charsigned char 时,不应直接将它们与标准算法一起使用。相反,首先将值转换为 unsigned char

std::string str_tolower(std::string s)
{
    std::transform(s.begin(), s.end(), s.begin(),
                // static_cast<int(*)(int)>(std::tolower)         // wrong
                // [](int c){ return std::tolower(c); }           // wrong
                // [](char c){ return std::tolower(c); }          // wrong
                   [](unsigned char c){ return std::tolower(c); } // correct
                  );
    return s;
}

[编辑] 示例

#include <cctype>
#include <clocale>
#include <iostream>
 
int main()
{
    unsigned char c = '\xb4'; // the character Ž in ISO-8859-15
                              // but ´ (acute accent) in 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

[编辑] 参见

将字符转换为大写
(函数) [编辑]
使用语言环境的 ctype facet 将字符转换为小写
(函数模板) [编辑]
将宽字符转换为小写
(函数) [编辑]
C 文档 关于 tolower

[编辑] 外部链接

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