红联Linux门户
Linux帮助

linux标准io的copy

发布时间:2015-12-25 09:52:43来源:linux网站作者:zhome

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


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);

}


2.用标准IO,以读写方式打开文件f3.txt,如果该文件不存在,则创建。如果该文件已经存在,则长度截短为0。

#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操作。当流涉及一个终端时(例如标准输入和输出),通常使用行缓冲。

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


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