iscntrl - cppreference.com
Namespaces
Variants

iscntrl

From cppreference.com
< c | string | byte
Defined in header <ctype.h>
int iscntrl( int ch );

Checks if the given character is a control character, i.e., codes [0x000x1F] and 0x7F.

The behavior is undefined if the value of ch is not representable as unsigned char and is not equal to EOF.

Parameters

ch - character to classify

Return value

Non-zero value if the character is a control character, zero otherwise.

Example

#include <ctype.h>
#include <locale.h>
#include <stdio.h>
 
int main(void)
{
    unsigned char c = '\x94'; // the control code CCH in ISO-8859-1
    printf("In the default C locale, \\x94 is %sa control character\n",
           iscntrl(c) ? "" : "not " );
    setlocale(LC_ALL, "en_GB.iso88591");
    printf("In ISO-8859-1 locale, \\x94 is %sa control character\n",
           iscntrl(c) ? "" : "not " );
}

Possible output:

In the default C locale, \x94 is not a control character
In ISO-8859-1 locale, \x94 is a control character

References

  • C23 standard (ISO/IEC 9899:2024):
  • 7.4.1.4 The iscntrl function (p: TBD)
  • C17 standard (ISO/IEC 9899:2018):
  • 7.4.1.4 The iscntrl function (p: 146)
  • C11 standard (ISO/IEC 9899:2011):
  • 7.4.1.4 The iscntrl function (p: 201)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.4.1.4 The iscntrl function (p: 182)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • 4.3.1.3 The iscntrl function

See also

checks if a wide character is a control character
(function) [edit]
C++ documentation for iscntrl