首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
自考
分别使用文件的系统调用read(fd,buf,nbytes)、write(fd,buf,nbytes)和文件的库函数fread(buf,size,nitems,fp)、fwrite(buf,size,nitems,fp),编写一个文件的复制程序(文件大小>
分别使用文件的系统调用read(fd,buf,nbytes)、write(fd,buf,nbytes)和文件的库函数fread(buf,size,nitems,fp)、fwrite(buf,size,nitems,fp),编写一个文件的复制程序(文件大小>
admin
2016-05-14
17
问题
分别使用文件的系统调用read(fd,buf,nbytes)、write(fd,buf,nbytes)和文件的库函数fread(buf,size,nitems,fp)、fwrite(buf,size,nitems,fp),编写一个文件的复制程序(文件大小>1MB)。当上述函数中nbytes、size和nitems都取值为1时(即一次读写一个字节),比较这两种程序的执行效率。当nbytes取4096字节,size取1字节,且niterns取4096时(即一次读写4096字节),再次比较这两种程序的执行效率。(可使用time命令)
选项
答案
循环执行系统调用write(fd,buf,1),每次调用向文件输出一个字节,但由于块设备读写是通过系统缓冲区进行的,故4096次写调用才需要一次实际的设备I/O操作,但需要4096次从用户态转换到核心态和核心态转回用户态的开销。 循环执行系统调用fwrite(buf,1,1,fp)时,每次操作向用户态空间的流文件缓冲区写入一个字节,4096次写操作填满该缓冲区后才发出一次write系统调用,转换到核心态,并进行一次实际的设备I/O操作。 因此两种方法花费设备I/O的时间是一样的,主要差别是流文件操作用4096次用户态函数的调用和返回的开销代替了直接使用系统调用时4096次用户态与核心态之间的切换。在实际系统中,一次函数调用所费的时间比用户态与核心态之间的切换所费的时间少得多,故当不是以整块的方法输入或输出数据时,使用流文件操作比使用系统调用效率高很多。 在程序清单17-1中,用例程gettimeofday()(该例程返回两个值:秒数tv_sec和微秒数tv_uBec)获得程序的开始计时时间和结束计时时间(精度为微秒),并计算程序段运行时所花的时间(单位为毫秒),被测试的输入文件大于4MB。测试结果说明,每次对文件输入/输出一个字节,使用流文件要比直接使用系统调用快得多,而每次对文件输入/输出4096字节,使用流文件与使用系统调用时间差不多,使用系统调用还快了一点点。 程序清单17-1.file_op.c #include<sys/stat.h> #include<sys/fcntl.h> #include<stdi0.h> #include<time.h> #define BUB_4096 4096 #define BUB_11 main(int argc,char*argv[1]) { int fd1,fd2; int n; char buf1[BUB_1],buf2[BUB_4096],buf3[BUB_1],buf4[BUB_40964]; struct timeVal start,end; /*测试系统调用read、write*/ gettimeofday(&start,NULL); fd1=open(argV[1],O_RDONLY); fd2=open(argV[2],O_WRONLY|O CREAA.0644); while((n=read(fd1,buf1,BUB_1))>0) write(fd2,buf1,n); gettimeofday(&end,NULL); printf("One byte every times:%5.3f\n", end.tv Sec*1000-start.tv sec*1000+end.tv uSec/1000-Start.tv usec/ 1000); n=0; gettimeofday(&start,NULL); while((n=read(fd1,buf2,BUB_4096))>0) write(fd2,buf2,n); gettimeofday(&end,NULL); printf("4096 byte every times:%5.3f\n", end.tv Sec*1000-start.tv Sec*1000+end.tv usec/1000-Start.tv usec/1000); /*测试流文件调用fread、fwrite*/ BILE*fp1,*fp2; fp1=fopen(argv[1],"rb"); fp2=fopen(argv[3],"wb"); gettimeofday(&start,NULL); while((n=fread(buf3,BUB_1,1,fp1))>0) fwrite(buf3,BUB_1,1,fp2); gettimeofday(&end,NULL); printf("One byte every times:%5.3f\n", end.tv sec*1000-Start.tv Sec*1000+end.tv uSec/1000-Start.tv usec/1000); gettimeofday(&start,NULL); while((n=fread(buf4,BUB 4096,4096,fp1))>0) fwrite(buf4,BUB4096,4096,fp2); fclose(fp1); fclose(fp2); gettimeofday(&end,NULL); printf("4096 byte every times:%5.3f\n", end.tv sec*1000-start.tv sec*1000+end.tv usec/1000-Start.tv usec/1000); }。
解析
转载请注明原文地址:https://jikaoti.com/ti/ujEaFFFM
本试题收录于:
操作系统题库理工类分类
0
操作系统
理工类
相关试题推荐
编制财务现金流量表目的是向_______系统说明项目编制和相应的财务分析。
下列关于双代号网络图的绘制原则说法不正确的是()
下列关于无节奏流水的施工特点说法不正确的是()
下列现象中,___________属于计算机运行的正常现象,与计算机病毒无关。()
ICMP响应分析探测技术本质是一种基于___________协议栈的操作系统指纹探测技术。()
OSI安全体系结构定义了五大类安全服务,其中数据机密性服务主要针对的安全威胁是()
什么是计算机病毒,如何进行定义?
已知下列资料。(1)计算工序G的ES和工序A的ES。(2)绘制如上表所示工程的网络图。(3)确定如上表所示工程的关键线路和工期。
在请求分页存储管理系统中,运行一个共有7页的作业,作业执行时访问页面的顺序为:0,5,1,3,0,1,2,5,0,4,2,6,4,3。系统为该作业分配4块内存块且初始状态为空。请用FIFO页面置换算法,用列表形式求出该作业执行完成后发生缺页次数和被淘汰的页
解决I/O设备与处理机速度不匹配的问题可以采用()
随机试题
属于糖皮质激素类的药物是
颈内动脉造影主要用于诊断
卫生事业单位统计人员要参加当地人民政府统计机构组织的
“气之本”指的是
某市A区甲公司和B区乙公司在C区订立购销合同,合同约定甲公司向乙公司出售100吨钢材,运输方式为代办托运。甲公司依照合同履约后,乙公司一直拖欠甲公司200万元的货款,甲公司与乙公司多次交涉还款事宜未果。甲公司得知乙公司无力还款,只有一座两层小楼租给了丙公司
[2000年第119题]从安全角度考虑,下列有关民用建筑门窗的设计,哪条是错的?
下列各项中,不符合企业所得税有关规定的是()。
票面利率为10%的息票债券,年初以面值1000元的价格买入,持有一年后,以1200元的价格卖出,该债券的回报率是()。
考生文件夹下存在一个数据库文件“samp3.accdb”,里面已经设计好表对象“tEmployee”和宏对象“m1”,同时还设计出以“tEmployee”为数据源的窗体对象“fEmployee”。试在此基础上按照以下要求补充窗体设计:在窗体的窗体页眉节
FromhumblebeginningsinagarageinMenloPark,Californiain1998,Googlehasgrownintoamultinationalcompanycarryingout
最新回复
(
0
)