linux c--标准IO

2021-03-08

标准I/O是ANSI C建立的一个标准I/O模型,是一个标准函数包和stdio.h头文件中的定义,具有一定的可移植性。标准I/O库处理很多细节。例如缓存分配,以优化长度执行I/O等。标准的I/O提供了三种类型的缓存。

  1. 全缓存:当填满标准I/O缓存后才进行实际的I/O操作。
  2. 行缓存:当输入或输出中遇到新行符时,标准I/O库执行I/O操作。
  3. 不带缓存:stderr就是了。

fopen

C 库函数FILE _fopen(const char _filename, const char *mode)使用给定的模式 mode 打开 filename 所指向的文件。

1
FILE *fopen(const char *filename, const char *mode)

参数

调用 fopen() 函数时必须指明读写权限,但是可以不指明读写方式(此时默认为"t")。

返回值

该函数返回一个 FILE 指针。否则返回 NULL,且设置全局变量 errno 来标识错误。

实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
#include <stdio.h>
#include <stdlib.h>

int main()
{
   FILE * fp;

   fp = fopen ("file.txt", "w+");
   fprintf(fp, "%s %s %s %d", "We", "are", "in", 2014);
   
   fclose(fp);
   
   return(0);
}

fclose

C 库函数int fclose(FILE *stream)关闭流 stream。刷新所有的缓冲区。

1
int fclose(FILE *stream)

参数

返回值

如果流成功关闭,则该方法返回零。如果失败,则返回 EOF。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
#include <stdio.h>

int main()
{
   FILE *fp;
 
   fp = fopen("file.txt", "w");

   fprintf(fp, "%s", "这里是 runoob.com");
   fclose(fp);
   
   return(0);
}

fread

C 库函数size_t fread(void _ptr, size_t size, size_t nmemb, FILE _stream)从给定流 stream 读取数据到 ptr 所指向的数组中。

1
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream)

参数

返回值

成功读取的元素总数会以 size_t 对象返回,size_t 对象是一个整型数据类型。如果总数与 nmemb 参数不同,则可能发生了一个错误或者到达了文件末尾。

实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include <stdio.h>
#include <string.h>
 
int main()
{
   FILE *fp;
   char c[] = "This is runoob";
   char buffer[20];
 
   /* 打开文件用于读写 */
   fp = fopen("file.txt", "w+");
 
   /* 写入数据到文件 */
   fwrite(c, strlen(c) + 1, 1, fp);
 
   /* 查找文件的开头 */
   fseek(fp, 0, SEEK_SET);
 
   /* 读取并显示数据 */
   fread(buffer, strlen(c)+1, 1, fp);
   printf("%s\n", buffer);
   fclose(fp);
   
   return(0);
}

fwrite

C 库函数size_t fwrite(const void _ptr, size_t size, size_t nmemb, FILE _stream)把 ptr 所指向的数组中的数据写入到给定流 stream 中。

1
size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream)

参数

返回值

如果成功,该函数返回一个 size_t 对象,表示元素的总数,该对象是一个整型数据类型。如果该数字与 nmemb 参数不同,则会显示一个错误。

注意

fwrite写完后文件流指针会偏移到写入字符串的最后位置

实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
#include<stdio.h>
 
int main ()
{
   FILE *fp;
   char str[] = "This is runoob.com";
 
   fp = fopen( "file.txt" , "w" );
   fwrite(str, sizeof(str) , 1, fp );
 
   fclose(fp);
  
   return(0);
}

fseek

C 库函数int fseek(FILE *stream, long int offset, int whence)设置流 stream 的文件位置为给定的偏移 offset,参数 offset 意味着从给定的 whence 位置查找的字节数。

1
int fseek(FILE *stream, long int offset, int whence)

参数

返回值

如果成功,则该函数返回零,否则返回非零值。

实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
#include <stdio.h>

int main ()
{
   FILE *fp;

   fp = fopen("file.txt","w+");
   fputs("This is runoob.com", fp);
  
   fseek( fp, 7, SEEK_SET );
   fputs(" C Programming Langauge", fp);
   fclose(fp);
   
   return(0);
}

ftell

C 库函数long int ftell(FILE *stream)返回给定流 stream 的当前文件位置。

1
long int ftell(FILE *stream)

参数

返回值

该函数返回位置标识符的当前值。如果发生错误,则返回 -1L,全局变量 errno 被设置为一个正值。

实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <stdio.h>

int main ()
{
   FILE *fp;
   long int len;

   fp = fopen("file.txt", "r");
   if( fp == NULL ) 
   {
      perror ("打开文件错误");
      return(-1);
   }
   // fseek  将文件标识符偏移到文件末尾
   fseek(fp, 0, SEEK_END);
   
   // 返回当前位置,这里在最后,可以用来表示文件大小
   len = ftell(fp);
   fclose(fp);

   printf("file.txt 的总大小 = %ld 字节\n", len);
   
   return(0);
}

freopen

以指定模式重新指定到另一个文件。模式用于指定新文件的访问方式。

头文件:stdio.h

C89函数声明:

1
FILE *freopen( const char *filename, const char *mode, FILE *stream );

C99函数声明:

1
FILE *freopen(const char * restrict filename, const char * restrict mode, FILE * restrict stream);

形参说明:

返回值:如果成功,则返回该指向该输出流的文件指针,否则返回为NULL。

示例:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
#include <stdio.h>

int main ()
{
   FILE *fp;

   printf("该文本重定向到 stdout\n");

   fp = freopen("file.txt", "w+", stdout);

   printf("该文本重定向到 file.txt\n");

   fclose(fp);
   
   return(0);
}

调用freopen()前会打印到标准输出 调用freopen()后会打印到file.txt

fgets

C 库函数char *fgets(char *str, int n, FILE *stream)从指定的流 stream 读取一行,并把它存储在 str 所指向的字符串内。当读取 (n-1) 个字符时,或者读取到换行符时,或者到达文件末尾时,它会停止,具体视情况而定。

1
2
3
#include <stdio.h>

char *fgets(char *str, int n, FILE *stream)

参数:

返回值:

ferror

C 库函数 int ferror(FILE *stream) 测试给定流 stream 的错误标识符。

1
2
3
#include <stdio.h>

int ferror(FILE *stream)

参数:

返回值:

如果设置了与流关联的错误标识符,该函数返回一个非零值,否则返回一个零值。

例子:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>

int main()
{
   FILE *fp;
   char c;

   fp = fopen("file.txt", "w");

   c = fgetc(fp);
   if( ferror(fp) )
   {
      printf("读取文件:file.txt 时发生错误\n");
   }
   clearerr(fp);
   if( ferror(fp) )
   {
      printf("读取文件:file.txt 时发生错误\n");
   }
   fclose(fp);

   return(0);
}

假设我们有一个文本文件 file.txt,它是一个空文件。让我们编译并运行上面的程序,因为我们试图读取一个以只写模式打开的文件,这将产生以下结果。

1
读取文件:file.txt 时发生错误
words: 2912 tags: linux c