_putc_nolock_putwc_nolock

将字符写入流,而不锁定。

语法

int _putc_nolock(
   int c,
   FILE *stream
);
wint_t _putwc_nolock(
   wchar_t c,
   FILE *stream
);

参数

c
要写入的字符。

stream
指向 FILE 结构的指针。

返回值

请参阅 putc、putwc

注解

_putc_nolock_putwc_nolock 与不带 _nolock 后缀的版本相同,但它们可能受到其他线程的干扰。 它们可能更快,因为它们不会产生锁定其他线程的开销。 仅在线程安全的上下文中使用这些函数,如单线程应用程序或调用范围已经处理线程隔离。

_putwc_nolock_putc_nolock 的宽字符版本;如果在 ANSI 模式下打开流,则这两个函数的行为相同。 _putc_nolock 当前不支持到 UNICODE 流中的输出。

默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 CRT 中的全局状态

一般文本例程映射

Tchar.h 例程 _UNICODE_MBCS 未定义 _MBCS 已定义 _UNICODE 已定义
_puttc_nolock _putc_nolock _putc_nolock _putwc_nolock

要求

例程 必需的标头
_putc_nolock <stdio.h>
_putwc_nolock <stdio.h> 或 <wchar.h>

通用 Windows 平台 (UWP) 应用中不支持控制台。 与控制台、stdinstdoutstderr 关联的标准流句柄必须重定向,然后 C 运行时函数才能在 UWP 应用中使用它们。 有关兼容性的详细信息,请参阅 兼容性

C 运行时库的所有版本。

示例

// crt_putc_nolock.c
/* This program uses putc to write buffer
* to a stream. If an error occurs, the program
* stops before writing the entire buffer.
*/

#include <stdio.h>

int main( void )
{
   FILE *stream;
   char *p, buffer[] = "This is the line of output\n";
   int  ch;

   ch = 0;
   /* Make standard out the stream and write to it. */
   stream = stdout;
   for( p = buffer; (ch != EOF) && (*p != '\0'); p++ )
      ch = _putc_nolock( *p, stream );
}

输出

This is the line of output

另请参阅

流 I/O
fputc, fputwc
getcgetwc