Share via


_fputc_nolock、_fputwc_nolock

写入流中的字符不锁定线程。

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

参数

  • c
    要写入的字符。

  • stream
    指向 FILE结构的指针。

返回值

这些函数都返回一个写好的字符。 有关的错误信息,请参阅fputc、fputwc

备注

_fputc_nolock 和 _fputwc_nolock 与 fputc 和 fputwc分别是相同的,除了它们不能避免来自由其他线程的干扰。 它们可能更快,因为它们不会产生锁定其他线程的开销。 仅在线程安全的上下文中使用这些函数,如单线程应用程序或调用范围已经处理线程隔离。

如果流在 ANSI 模式中打开,这两个函数具有相同的行为。 _fputc_nolock 当前不支持输出到 UNICODE 流。

一般文本例程映射

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 应用商店 应用程序中不受支持。 与控制台 stdin、stdout 和 stderr 关联的标准流句柄必须重定向,然后 C 运行时函数才可以在 Windows 应用商店 应用程序中使用它们。 有关兼容性的更多信息,请参见兼容性

示例

// 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 ) ;

}
  

.NET Framework 等效项

请参见

参考

流 I/O

fgetc、fgetwc

putc、putwc