linux标准io的copy

---恢复内容开始---

1.linux标准io的copy

#include<stdio.h>

int main(int argc,char **argv)

{

if(argc<3)

{

printf("use:mycp file1 file2\n");

return -1;

}

FILE *src=fopen(argv[1],"r");//打开源文件

if(src==NULL)

{

printf("no file!\n");

return -1;

}

FILE *dest=fopen(argv[2],"w");

if(dest==NULL)

{

printf("no file!\n");

fclose(src);

return -1;

}

int ret=fseek(src,0,SEEK_END);

long len=ftell(src);

rewind(src);

char buffer[len];

ret=fread(buffer,len,1,src);

ret=fwrite(buffer,len,1,dest);

fclose(src);

fclose(dest);

}

#include<stdio.h>

#include<string.h>

#include<errno.h>

int main(int argc,char argv[])

{

FILE *fp;

if((fp=fopen("f3.txt","w+"))==NULL)//打开文件的路径和路径名,打开文件的状态

{

fprintf(stderr,"fopen() failed:%s\n",strerror(errno));

return -1;

}

fclose(fp);

return 0;

}

1:标准IO库操作是围绕着流来进行的,当我们通过fopen标准IO库函数打开一个文件,我们就使一个文件和一个IO流相关联。在这里我们把IO流和文件指针FILE*等同起来,因为所有针对IO流的操作都是通过FILE*指针来实现的。

2:标准IO库引入了IO缓存,通过累积一定量的IO数据后,然后集中写入到实际的文件中来减少系统调用,从而提高IO效率。标准IO库会自动管理内部的缓存,不需要程序员介入。然而,也正是因为我们看不到标准IO库的缓存:

3:该对象通常是一个结构,它包含了标准IO库为管理该流所需要的所有信息,包括:用于实际IO的文件描述符、指向用于该流缓冲区的指针、缓冲区的长度、当前在缓冲区中的字符数以及出错标志等等。

4:文件缓冲

目的:尽量减少使用 read/write的调用次数

定义:系统自动的在内存中为每一个正在使用的文件开辟一个缓冲区,从内存向磁盘输出数据必须先送到内存缓冲区,装满缓冲区在一起送到磁盘中去。从磁盘中读数据,则一次从磁盘文件将一批数据读入到内存缓冲区中,然后在从缓冲区逐个的将数据送到程序的数据区。

分类:全缓存、行缓存、不缓存。

;全缓冲:在填满标准IO缓冲区后才进行实际IO操作。对于驻留在磁盘上的文件通常是由标准IO库实施全缓冲的。在一个流上执行第一次IO操作时,相关标准IO函数通常调用malloc获得需使用的缓冲区。flush,说明标准IO缓冲区的写操作。缓冲区可由标准IO历程自动冲洗,或者可调用函数fflush冲洗一个流。

;行缓存 : 这种情况下,当在输入和输出中遇到换行符时,刷新一次,标准IO库执行IO操作。这允许我们一次输出一个字符(用标准IO fputs函数),但只有在谢了一行之后才进行实际IO操作。当流涉及一个终端时(例如标准输入和输出),通常使用行缓冲。

;不缓存:不对字符进行缓冲。

---恢复内容结束---

上一篇:unix 全缓冲、行缓冲、无缓冲


下一篇:SASS学习笔记!(持续学习中..)