共用方式為


ungetc、ungetwc

推一個字元到資料流上。

int ungetc(
   int c,
   FILE *stream 
);
wint_t ungetwc(
   wint_t c,
   FILE *stream 
);

參數

  • c
    待推回的字元。

  • stream
    指向 FILE 結構的指標。

傳回值

如果成功的話,這些函式都會傳回字元引數的 c*。*如果 c 無法推回,或是未讀取字元,輸入資料流不會變更和 ungetc 會傳回 EOF; ungetwc 會傳回 WEOF。 如果 stream 是 NULL,則叫用無效參數處理常式,如 參數驗證 中所述。 如果允許繼續執行, EOF 或 WEOF 會回傳並將 errno 設為 EINVAL 。

如需有關這些錯誤碼和其他錯誤碼的詳細資訊,請參閱 _doserrno、errno、_sys_errlist 和 _sys_nerr

備註

ungetc 函式推後字元 c 在 stream 上並清除檔案結尾指示器。 資料流必須開啟為唯讀。 在 stream 上執行後續讀取作業開頭為 c*。*使用 ungetc 被忽略而嘗試推入EOF 至資料流上 。

如果 fflush、 fseek、 fsetpos或 rewind 呼叫,可能會在字元從目前資料流讀取之前清除資料流位置的字元則為 ungetc 。 其檔案位置指示器會有值,在字元會推回之前。 與資料流相對應的外儲存不變。 在物件的文字資料流的成功呼叫 ungetc ,檔案位置指示器是未指定的,直到所有被推回的字元讀取或捨棄。 在對二進位資料流的每次成功呼叫 ungetc ,檔案位置指示器遞減;如果其值為 0,則在呼叫,值會在呼叫後未定義。

ungetc ,如果呼叫兩次,而兩個呼叫之間讀取或檔案當地語系化作業,結果會無法預期。 在對 fscanf的呼叫,對 ungetc 的呼叫可能會失敗後,除非另一次讀取作業 (例如 getc) 執行。 這是因為fscanf 會本身呼叫 ungetc。

ungetwc 是 ungetc的寬字元版本。 不過,在對文字或二進位資料流的每次成功呼叫 ungetwc ,檔案位置指示器的值未指定,直到所有被推回的字元讀取或捨棄。

這些函式是安全執行緒並在執行期間鎖定敏感性資料。 如需非鎖定版本,請參閱 _ungetc_nolock、_ungetwc_nolock

一般文字常式對應

TCHAR.H 常式

未定義 _UNICODE & _MBCS

已定義 _MBCS

已定義 _UNICODE

_ungettc

ungetc

ungetc

ungetwc

需求

常式

必要的標頭

ungetc

<stdio.h>

ungetwc

<stdio.h> 或 <wchar.h>

Windows 市集 應用程式不支援主控台。 與主控台關聯的標準資料流控制代碼 (stdin、stdout 和 stderr) 必須重新導向,然後 C 執行階段函式才能在 Windows 市集 應用程式中使用它們。 如需其他相容性資訊,請參閱相容性

範例

// crt_ungetc.c
// This program first converts a character
// representation of an unsigned integer to an integer. If
// the program encounters a character that is not a digit,
// the program uses ungetc to replace it in the  stream.
//

#include <stdio.h>
#include <ctype.h>

int main( void )
{
   int ch;
   int result = 0;

   // Read in and convert number:
   while( ((ch = getchar()) != EOF) && isdigit( ch ) )
      result = result * 10 + ch - '0';    // Use digit.
   if( ch != EOF )
      ungetc( ch, stdin );                // Put nondigit back.
   printf( "Number = %d\nNext character in stream = '%c'", 
            result, getchar() );
}
  

.NET Framework 對等用法

不適用。若要呼叫標準 C 函式,請使用 PInvoke。如需詳細資訊,請參閱平台叫用範例

請參閱

參考

資料流 I/O

getc、getwc

putc、putwc