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。如需詳細資訊,請參閱平台叫用範例。