How ungetch() Works with getch() and getche()

Last reviewed: July 17, 1997
Article ID: Q41198
5.10 6.00 6.00a 6.00ax 7.00 | 5.10 6.00 6.00a | 1.00 1.50
MS-DOS                      | OS/2            | WINDOWS
kbprg

The information in this article applies to:

  • The C Run-time (CRT), included with:

        - Microsoft C for MS-DOS, versions 5.1, 6.0, 6.0a, and 6.0ax
        - Microsoft C for OS/2, versions 5.1, 6.0, and 6.0a
        - Microsoft C/C++ for MS-DOS, version 7.0
        - Microsoft Visual C++ for Windows, versions 1.0 and 1.5
    

SUMMARY

The Microsoft C run-time function ungetch() pushes back a character to be read in by the next call to getch() or getche().

The character is pushed back to a internal buffer, not the keyboard buffer. The function getch() or getche() checks the internal buffer before it calls the DOS interrupt function to read input from the keyboard buffer. If the internal buffer is not empty, it returns the value in the buffer without calling the Interrupt 21H function.

MORE INFORMATION

Pushing a character back to the keyboard buffer can be done on some machines by calling BIOS keyboard service, Interrupt 16H function 05H with scan code in the register CH and the character's ASCII code in the register CL. Note that this BIOS function may not be supported on all machines. Be sure to check the BIOS documentation for your machine before you try to use this function.


Additional reference words: kbinf 5.00 5.10 6.00 6.00a 6.00ax 7.00 1.00
1.50
KBCategory: kbprg
KBSubcategory: CRTIss
Keywords : kb16bitonly


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: July 17, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.