std::islower
来自cppreference.com
| 在标头 <cctype> 定义
|
||
| |
||
检查给定字符是否被当前 C 本地环境分类为小写字符。默认 "C" 本地环境中,std::islower 仅对小写字母(abcdefghijklmnopqrstuvwxyz)返回非零值。
若 islower 返回非零值,则保证同一 C 本地环境中 std::iscntrl、std::isdigit、std::ispunct 和 std::isspace 对同一字符返回零。
若 ch 不可表示为 unsigned char 且不等于 EOF 则行为未定义。
参数
| ch | - | 要分类的字符 |
返回值
若字符为小写字母则为非零值,否则为零。
注解
同所有其他来自 <cctype> 的函数,若实参值既不能表示为 unsigned char 又不等于 EOF 则 std::islower 的行为未定义。为了以单纯的 char(或 signed char)安全使用此函数,首先要将实参转换为 unsigned char:
bool my_islower(char ch)
{
return std::islower(static_cast<unsigned char>(ch));
}
类似地,迭代器的值类型为 char 或 signed char 时,不应直接将它们用于标准算法。而是要首先转换值为 unsigned char:
int count_lowers(const std::string& s)
{
return std::count_if(s.begin(), s.end(),
// static_cast<int(*)(int)>(std::islower) // 错误
// [](int c){ return std::islower(c); } // 错误
// [](char c){ return std::islower(c); } // 错误
[](unsigned char c){ return std::islower(c); } // 正确
);
}
示例
运行此代码
#include <cctype>
#include <clocale>
#include <iostream>
int main()
{
unsigned char c = '\xe5'; // ISO-8859-1 中的字母 å
std::cout << "islower(\'\\xe5\', 默认 C 本地环境) 返回 "
<< std::boolalpha << (bool)std::islower(c) << '\n';
std::setlocale(LC_ALL, "en_GB.iso88591");
std::cout << "islower(\'\\xe5\', ISO-8859-1 本地环境) 返回 "
<< std::boolalpha << (bool)std::islower(c) << '\n';
}
可能的输出:
islower('\xe5', 默认 C 本地环境) 返回 false
islower('\xe5', ISO-8859-1 本地环境) 返回 true
参阅
| 检查字符是否被本地环境分类为小写 (函数模板) | |
| 检查宽字符是否为小写 (函数) | |
islower 的 C 文档
| |
