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