%>

从流中读取字符。

语法

int fgetc(
   FILE *stream
);
wint_t fgetwc(
   FILE *stream
);

参数

stream
指向 FILE 结构的指针。

返回值

fgetc 返回作为 int 读取的字符或返回 EOF 以指示错误或文件尾。 fgetwcwint_t 形式返回与读取的字符相对应的宽字符,或者返回 WEOF 来指示错误或文件结束。 对于这两个函数,使用 feofferror 来区分错误和文件结尾条件。 如果发生读取错误,则会设置流的错误指示器。 如果 streamNULL,则 fgetcfgetwc 将调用无效参数处理程序,如参数验证中所述。 如果允许执行继续,则这些功能将 errno 设置为 EINVAL 并返回 EOF

备注

其中每个函数均从与 stream 关联的文件的当前位置读取单个字符。 然后该函数递增关联的文件指针(如果已定义)以指向下一个字符。 如果流位于文件结尾,则设置流的文件结尾指示器。

fgetc 等效于 getc,但仅作为函数实现,而不是同时作为函数和宏实现。

fgetwcfgetc 的宽字符版本;它根据 stream 是在文本模式还是二进制模式中打开,来将 c 读取为多字节字符或宽字符

_nolock 后缀的版本相同,但可能受到其他线程的干扰。

有关在文本模式和二进制模式下处理宽字符和多字节字符的详细信息,请参阅文本模式和二进制模式下的 Unicode 流 I/O

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

一般文本例程映射

TCHAR.H 例程 _UNICODE_MBCS 未定义 _MBCS 已定义 _UNICODE 已定义
_fgettc fgetc fgetc fgetwc

要求

函数 必需的标头
fgetc <stdio.h>
fgetwc <stdio.h> 或 <wchar.h>

有关兼容性的详细信息,请参阅 兼容性

示例

// crt_fgetc.c
// This program uses getc to read the first
// 80 input characters (or until the end of input)
// and place them into a string named buffer.

#include <stdio.h>
#include <stdlib.h>

int main( void )
{
   FILE *stream;
   char buffer[81];
   int  i, ch;

   // Open file to read line from:
   fopen_s( &stream, "crt_fgetc.txt", "r" );
   if( stream == NULL )
      exit( 0 );

   // Read in first 80 characters and place them in "buffer":
   ch = fgetc( stream );
   for( i=0; (i < 80 ) && ( feof( stream ) == 0 ); i++ )
   {
      buffer[i] = (char)ch;
      ch = fgetc( stream );
   }

   // Add null to end string
   buffer[i] = '\0';
   printf( "%s\n", buffer );
   fclose( stream );
}

输入:crt_fgetc.txt

Line one.
Line two.

输出

Line one.
Line two.

另请参阅

流 I/O
%>
%>