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

std::toupper

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

Преобразует заданный символ в верхний регистр в соответствии с правилами преобразования символов, определёнными установленной в данный момент локалью C.

В локали по умолчанию "C" следующие строчные буквы abcdefghijklmnopqrstuvwxyz заменяются соответствующими прописными буквами ABCDEFGHIJKLMNOPQRSTUVWXYZ.

Содержание

[править] Параметры

ch символ для преобразования. Если значение ch не представляется как unsigned char и не равно EOF, поведение не определено.

[править] Возвращаемое значение

Преобразованный символ или ch, если текущая локаль C не определяет версию в верхнем регистре.

[править] Примечание

Как и все другие функции из <cctype>, поведение std::toupper не определено, если значение аргумента не может быть представлено как unsigned char и не равно EOF. Чтобы безопасно использовать эти функции с простыми char (или signed char), аргумент сначала должен быть преобразован в unsigned char:

char my_toupper(char ch)
{
    return static_cast<char>(std::toupper(static_cast<unsigned char>(ch)));
}

Также, их не следует использовать напрямую со стандартными алгоритмами, если тип значения итератора является char или signed char. Вместо этого сначала преобразуйте значение в unsigned char:

std::string str_toupper(std::string s)
{
    std::transform(s.begin(), s.end(), s.begin(), 
                // static_cast<int(*)(int)>(std::toupper)         // неправильно
                // [](int c){ return std::toupper(c); }           // неправильно
                // [](char c){ return std::toupper(c); }          // неправильно
                   [](unsigned char c){ return std::toupper(c); } // правильно
                  );
    return s;
}

[править] Пример

#include <cctype>
#include <clocale>
#include <iostream>
 
int main()
{
    unsigned char c = '\xb8'; // символ ž в ISO-8859-15
                              // но ¸ (седиль) в ISO-8859-1
 
    std::setlocale(LC_ALL, "en_US.iso88591");
    std::cout << std::hex << std::showbase;
    std::cout << "в iso8859-1, toupper('0xb8') даёт " << std::toupper(c) << '\n';
    std::setlocale(LC_ALL, "en_US.iso885915");
    std::cout << "в iso8859-15, toupper('0xb8') даёт " << std::toupper(c) << '\n';
}

Вывод:

в iso8859-1, toupper('0xb8') даёт 0xb8
в iso8859-15, toupper('0xb8') даёт 0xb4

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

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