命名空间
变体
操作

ungetwc

来自 cppreference.cn
< c‎ | io
 
 
文件输入/输出
类型和对象
        
函数
文件访问
(C95)
无格式输入/输出
(C95)(C95)
(C95)
(C95)(C95)
(C95)
ungetwc
(C95)

格式化输入
 
定义于头文件 <wchar.h>
wint_t ungetwc( wint_t ch, FILE *stream );
(since C95)

如果 ch 不等于 WEOF,则将宽字符 ch 推入与流 stream 关联的输入缓冲区,以便后续从 stream 读取操作将检索该宽字符。与流关联的外部设备未被修改。

流重新定位操作 fseek, fsetpos, 和 rewind 丢弃 ungetwc 的效果。

如果多次调用 ungetwc 而没有中间的读取或重新定位,则可能会失败(换句话说,保证大小为 1 的回推缓冲区,但任何更大的缓冲区都是实现定义的)。如果执行了多次成功的 ungetwc,则读取操作将按 ungetwc 的相反顺序检索回推的宽字符

如果 ch 等于 WEOF,则操作失败,并且流不受影响。

成功调用 ungetwc 会清除文件结束状态标志 feof

在流(无论是文本还是二进制)上成功调用 ungetwc 会以未指定的方式修改流位置指示符,但保证在通过读取操作检索所有回推的宽字符后,流位置指示符等于其在 ungetwc 之前的值。

目录

[编辑] 参数

ch - 要放回的宽字符
stream - 要将宽字符放回的文件流

[编辑] 返回值

成功时返回 ch

失败时返回 WEOF,并且给定的流保持不变。

[编辑] 参考

  • C11 标准 (ISO/IEC 9899:2011)
  • 7.29.3.10 ungetwc 函数 (p: 425-426)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.24.3.10 ungetwc 函数 (p: 370-371)

[编辑] 参见

将字符放回文件流
(函数) [编辑]
从文件流获取宽字符
(函数) [编辑]
C++ 文档 for ungetwc