%>
将字符写入流,而不锁定。
语法
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 流中的输出。
默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 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) 应用中不支持控制台。 与控制台关联的标准流句柄(stdin
、stdout
和 stderr
)必须重定向,然后 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
%>
%>