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

std::ispunct

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

Проверяет, является ли данный символ символом пунктуации, классифицированным текущей локалью C. Локаль C по умолчанию классифицирует символы !"#$%&'()*+,-./:;<=>?@[\]^_`{|}~ как символы пунктуации.

Поведение не определено, если значение ch не может быть представлено как unsigned char и не равно EOF.

Содержание

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

chсимвол для классификации

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

Ненулевое значение, если символ является знаком пунктуации, иначе ноль.

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

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

bool my_ispunct(char ch)
{
    return std::ispunct(static_cast<unsigned char>(ch));
}

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

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

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

#include <cctype>
#include <clocale>
#include <iostream>
 
int main()
{
    unsigned char c = '\xd7'; // символ × (знак умножения) в ISO-8859-1
 
    std::cout << "ispunct(\'\\xd7\', локаль C по умолчанию) возвращает "
              << std::boolalpha << (bool)std::ispunct(c) << '\n';
 
    std::setlocale(LC_ALL, "en_GB.iso88591");
    std::cout << "ispunct(\'\\xd7\', локаль ISO-8859-1) возвращает "
              << std::boolalpha << (bool)std::ispunct(c) << '\n';
}

Возможный вывод:

ispunct('\xd7', локаль C по умолчанию) возвращает false
ispunct('\xd7', локаль ISO-8859-1) возвращает true

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

проверяет, классифицируется ли символ локалью как знак препинания
(шаблон функции) [править]
проверяет, является ли широкий символ символом пунктуации
(функция) [править]
ASCII значениясимволы

iscntrl
iswcntrl

isprint
iswprint

isspace
iswspace

isblank
iswblank

isgraph
iswgraph

ispunct
iswpunct

isalnum
iswalnum

isalpha
iswalpha

isupper
iswupper

islower
iswlower

isdigit
iswdigit

isxdigit
iswxdigit

деся-тичныешестнад-цатерич-ныевосьме-ричные
0–8\x0\x8\0\10управляющие коды (NUL, и т.д.)≠000000000000
9\x9\11табуляция (\t)≠00≠0≠000000000
10–13\xA\xD\12\15пробельные (\n, \v, \f, \r)≠00≠0000000000
14–31\xE\x1F\16\37управляющие коды≠000000000000
32\x20\40пробел0≠0≠0≠000000000
33–47\x21\x2F\41\57!"#$%&'()*+,-./0≠000≠0≠0000000
48–57\x30\x39\60\7101234567890≠000≠00≠0000≠0≠0
58–64\x3A\x40\72\100:;<=>?@0≠000≠0≠0000000
65–70\x41\x46\101\106ABCDEF0≠000≠00≠0≠0≠000≠0
71–90\x47\x5A\107\132GHIJKLMNOP
QRSTUVWXYZ
0≠000≠00≠0≠0≠0000
91–96\x5B\x60\133\140[\]^_`0≠000≠0≠0000000
97–102\x61\x66\141\146abcdef0≠000≠00≠0≠00≠00≠0
103–122\x67\x7A\147\172ghijklmnop
qrstuvwxyz
0≠000≠00≠0≠00≠000
123–126\x7B\x7E\172\176{|}~0≠000≠0≠0000000
127\x7F\177символ возврата (DEL)≠000000000000