std::tolower — cppreference.com
Материал из cppreference.com
<tbody> </tbody>
| Определено в заголовочном файле |
||
|
|
||
Преобразует заданный символ в нижний регистр в соответствии с правилами преобразования символов, определёнными установленной в данный момент локалью C.
В локали по умолчанию "C" следующие прописные буквы ABCDEFGHIJKLMNOPQRSTUVWXYZ заменяются соответствующими строчными буквами abcdefghijklmnopqrstuvwxyz.
Параметры
| ch | — | символ для преобразования. Если значение ch не может быть представлено как unsigned char и не равно EOF, поведение не определено
|
Возвращаемое значение
Версия ch в нижнем регистре или неизменённый ch, если в текущей локали C не указана версия в нижнем регистре.
Примечание
Как и все другие функции из <cctype>, поведение std::tolower не определено, если значение аргумента не может быть представлено как unsigned char и не равно EOF. Чтобы безопасно использовать эти функции с простыми 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 << "в iso8859-1, tolower('0xb4') даёт " << std::tolower(c) << '\n'; std::setlocale(LC_ALL, "en_US.iso885915"); std::cout << "в iso8859-15, tolower('0xb4') даёт " << std::tolower(c) << '\n'; }
Возможный вывод:
в iso8859-1, tolower('0xb4') даёт 0xb4
в iso8859-15, tolower('0xb4') даёт 0xb8