博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UNIX环境高级编程笔记之文件I/O
阅读量:6371 次
发布时间:2019-06-23

本文共 1072 字,大约阅读时间需要 3 分钟。

一、总结

  在写之前,先唠几句,《UNIX环境高级编程》,简称APUE,这本书简直是本神书,像我这种小白,基本上每看完一章都是“哇”这种很吃惊的表情。其实大概三年前,那会大三,我就买了这本书,也看过一些,但好像没有留下什么印象,今天再看,依然觉得像新的一样。很大的原因我想是一直以来都在用windows(用windows做开发为什么学不到真正的技术,我想大家都懂的),当然知识结构不完整,学习能力这些就不说了。所以,对于那些致力于想在Linux下做开发的人来说,这本说一定是强推的。

  如果你分得清write和发fwrite,read和fread这些函数的区别,那这章也许就对你没什么吸引力了。本人之前面试腾讯,也被问到这个问题,当时胡乱瞎扯了一通,也真是囧。

  这章大体上讲了两件事:1)什么是不带缓冲的I/O;2)如何在多个进程间共享文件。作为总结,我用自己的话简单说一下这两个问题,详细的内容可以看上面这幅图。

  对于第一个问题,不带缓冲指的是每个read和write这些文件I/O操作都调用的是系统调用,属于内核态的操作。而诸如fread和fwrite这些标准I/O操作属于用户态操作,具体是库函数的实现,需要借助用户缓冲区来实现(关于用户态和内核态的理解请看)。所以,不带缓冲是相对带用户缓冲区来说的(如果只从字面上理解缓冲,其实文件I/O也是带缓冲的,只不过内核缓冲区,具体后面开一篇博客来讲)

  对于第二个问题,文件的共享需要让多个文件间扯上关系,不然也没辙。UNIX使用三种数据结构(进程表项,文件表项和V-Node节点表项)来表示一个打开的文件,如下图。这样当多个进程访问一个文件,只用新建一个进程表项,然后引用对应的文件即可。其中存在着:一个进程对应一个独立的文件表项,一个文件仅有一个V-Node表项。

  因为一个文件仅有一个V-Node表项,所以,为了保证文件在多个进程间共享,需要谨慎处理好文件的一致性。比如两个进程A和B要写数据到一个文件,一般调用的是lseek和write这两个函数,首先A lseek写入的位置(如1500),然后转到B 也lseek到1500,又转到A开始write 100个字节,文件长度变为1600个字节,又转到B,但B此时从第1500个字节处开始write,这就造成写文件错误。因此,对于这样的多个操作造成文件共享信息的不一致,UNIX给出的解决方案是原子操作,对于上面这种情况的一个解决方案是使用open+O_APPEND组合的原子操作。

 

二、看图说话

一图胜过千言,看图!

 

 

转载地址:http://ctuqa.baihongyu.com/

你可能感兴趣的文章
你所不知道的Python | 字符串连接的秘密
查看>>
K8S漏洞报告 | 近期bug fix解读&1.13主要bug fix汇总
查看>>
【开放平台】各平台相关API搜集&调用遇到问题一览表(Javascript版本)
查看>>
网传某厂商要求潜规则showgirl 经纪公司发声明澄清
查看>>
Apollo简介和源码搭建
查看>>
ThinkPHP 利用.htaccess文件的 Rewrite 规则隐藏URL中的 index...
查看>>
教你如何在博客园放“可运行"代码
查看>>
前后端分离-Rest Api设计
查看>>
一夜梦醒
查看>>
redis(9)、redis集群之redis Cluster使用
查看>>
spring-101-springAOP
查看>>
shell基础语法
查看>>
maven地址
查看>>
echarts例子
查看>>
指针可以有空值
查看>>
windows下通过VNC图形化访问Ubuntu桌面环境
查看>>
window.showModalDialog以及window.open用法简介
查看>>
CSS控制print打印样式
查看>>
js有中文英文逗号的字符串怎么分割成数组
查看>>
【Java】常用字符编码
查看>>