Linux文件编程之标准C库

本文详细介绍了Linux下文件编程中的标准C库,包括fopen、fwrite、fread、fseek等函数的用法,对比了open系统调用的区别,并探讨了缓冲文件系统在提高效率上的作用。通过本文,读者可以更好地理解在不同场景下如何选择合适的文件操作函数。
摘要由CSDN通过智能技术生成

前言

        关于open跟fopen,对于这两个名字很类似的函数,对很对初学者来说不容易搞清楚他们有什么不同,只知道按照函数用法使用。如果能很好地区分两者相信大家对于C语言和UNIX系统(包括Linux系统)有更加深入的了解。

一、来源

从来源的角度看,两者能很好地分开,这也是两者最显而易见的区别:

        open:是UNIX系统调用函数(包括Linux等),返回的是文件描述符,他是文件在文件描述符表里的索引。

        fopen:是ANSIC标准中的C语言库函数,在不同系统中调用不同的内核api。返回的是一个指向文件结构的指针。        

二、移植性

        fopen是标准C库函数,因此拥有良好的移植性;而open则是UNIX系统调用,移植性有限。

        如:Window下相似的功能使用API函数CreateFile

三、适用范围

        open返回文件描述符,而文件描述符是UNIX系统下一个重要概念,UNIX下一切设备都是文件的形式操作。如网络套接字、硬件设备。当然包括操作普通正规文件(Regular File)。

        fopen是用来操纵普通正规文件(Regular File)的。

四、文件IO层次

        如果从文件IO角度来看,前者属于低级IO函数,后者属于高级IO函数。低级和高级的简单区分标准是:谁离系统内核更近。低级文件IO运行在内核态,高级文件IO运行在用户态。

五、缓冲

  1. 缓冲文件系统 
    缓冲文件系统的特点是:在内存开辟一个“缓冲区”,为程序中的每一个文件使用;当执行读文件的操作时,从磁盘文件将数据先读入内存“缓冲区”,装满后再从内存“缓冲区”依此读出需要的数据。执行写文件的操作时,先将数据写入内存“缓冲区”,待内存“缓冲区”装满后再写入文件。由此可以看出,内存“缓冲区”的大小,影响着实际操作外存的次数,内存“缓冲区”越大,则操作外存的次数就少,执行速度就快、效率高。一般来说,文件“缓冲区”的大小随机器 而定。fopen, fclose, fread, fwrite, fgetc, fgets, fputc, fputs, freopen, fseek, ftell, rewind等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值