分享方式:


%

將字元寫入資料流,而不需要鎖定。

語法

int _fputc_nolock(
   int c,
   FILE *stream
);
wint_t _fputwc_nolock(
   wchar_t c,
   FILE *stream
);

參數

c
待寫入字元。

stream
FILE 結構的指標。

傳回值

所有這些函式都會傳回寫入的字元。 如需錯誤資訊,請參閱 fputcfputwc

備註

_fputc_nolock_fputwc_nolock 分別與 fputcfputwc 完全一致,不同之處在於其不受保護,不能免於其他執行緒的干擾。 因為其不會造成鎖定其他執行緒的額外負荷,所以可能會比較快。 這些函式只能用在安全執行緒內容 (例如單一執行緒應用程式) 或呼叫範圍已經處理執行緒隔離的地方。

如果資料流是以 ANSI 模式開啟,則這兩個函式的行為相同。 _fputc_nolock 目前不支援輸出至 UNICODE 資料流。

根據預設,此函式的全域狀態會限定於應用程式。 若要變更此行為,請參閱 CRT 中的全域狀態

一般文字常式對應

Tchar.h 常式 _UNICODE_MBCS 未定義 _MBCS 已定義 _UNICODE 已定義
_fputtc_nolock _fputc_nolock _fputc_nolock _fputwc_nolock

需求

函式 必要的標頭
_fputc_nolock <stdio.h>
_fputwc_nolock <stdio.h> 或 <wchar.h>

通用 Windows 平台 (UWP) 應用程式中不支援主控台。 與主控台相關聯的標準資料流控制代碼 (stdinstdoutstderr) 必須重新導向,之後 C 執行階段函式才能在 UWP 應用程式中使用它們。 如需相容性詳細資訊,請參閱相容性

範例

// crt_fputc_nolock.c
// This program uses _fputc_nolock
// to send a character array to stdout.

#include <stdio.h>

int main( void )
{
   char strptr1[] = "This is a test of _fputc_nolock!!\n";
   char *p;

   // Print line to stream using fputc.
   p = strptr1;
   while( (*p != '\0') && _fputc_nolock( *(p++), stdout ) != EOF ) ;

}
This is a test of _fputc_nolock!!

另請參閱

資料流 I/O
fgetc??fgetwc
putc??putwc