_getch, _getwch

Получает символ из консоли без отображения.

Важно!

Этот API нельзя использовать в приложениях, выполняемых в среде выполнения Windows. Дополнительные сведения: Функции CRT, которые не поддерживаются в приложениях универсальной платформы Windows.

Синтаксис

int _getch( void );
wint_t _getwch( void );

Возвращаемое значение

Возвращает считанный символ. Ошибка не возвращается.

Комментарии

Функции _getch и _getwch считывают один символ из консоли без повтора символа. Для чтения функциональной клавиши или клавиши со стрелками каждая функция должна вызываться дважды. Первый вызов возвращает 0 или 0xE0. Второй вызов возвращает код сканирования ключа.

Эти функции блокируют вызывающий поток и поэтому являются потокобезопасны. Сведения о версиях без блокировки см. в разделе _getch_nolock, _getwch_nolock.

По умолчанию глобальное состояние этой функции ограничивается приложением. Чтобы изменить это поведение, см. статью Глобальное состояние в CRT.

Сопоставления подпрограмм универсального текста

Tchar.h Обычной _UNICODE и _MBCS не определены _MBCS Определенные _UNICODE Определенные
_gettch _getch _getch _getwch

Требования

Подпрограмма Обязательный заголовок
_getch <conio.h>
_getwch <conio.h> или <wchar.h>

Дополнительные сведения о совместимости см. в разделе Compatibility.

Пример

// crt_getch.c
// compile with: /c
// This program reads characters from
// the keyboard until it receives a 'Y' or 'y'.

#include <conio.h>
#include <ctype.h>

int main( void )
{
   int ch;

   _cputs( "Type 'Y' when finished typing keys: " );
   do
   {
      ch = _getch();
      ch = toupper( ch );
   } while( ch != 'Y' );

   _putch( ch );
   _putch( '\r' );    // Carriage return
   _putch( '\n' );    // Line feed
}
abcdefy
Type 'Y' when finished typing keys: Y

См. также раздел

Ввод-вывод на консоль и порт
_getche, _getwche
_cgets, _cgetws
getc, getwc
_ungetch, _ungetwch, _ungetch_nolock, _ungetwch_nolock