Пространства имён
Варианты
Действия

std::tolower

Материал из cppreference.com
< cpp‎ | string‎ | byte
 
 
 
Однобайтовые строки с завершающим нулём
Функции
Манипуляции с символами
Преобразование в числовые форматы
(C++11)(C++11)
(C++11)(C++11)
Манипуляции со строками
Проверка строки
Манипуляции с памятью
Разное
 
Определено в заголовочном файле <cctype>
int tolower( int ch );

Преобразует заданный символ в нижний регистр в соответствии с правилами преобразования символов, определёнными установленной в данный момент локалью 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

[править] Смотрите также

преобразует символ в верхний регистр
(функция) [править]
преобразует символ в нижний регистр, используя фасет ctype локали
(шаблон функции) [править]
преобразует широкий символ в нижний регистр
(функция) [править]