zoukankan      html  css  js  c++  java
  • (八)open函数的flag详解

    3.1.4.open函数的flag详解1
    3.1.4.1、读写权限:O_RDONLY O_WRONLY O_RDWR
    (1)linux中文件有读写权限,我们在open打开文件时也可以附带一定的权限说明(譬如O_RDONLY就表示以只读方式打开,O_WRONLY表示以只写方式打开,O_RDWR表示以可读可写方式打开)
    (2)当我们附带了权限后,打开的文件就只能按照这种权限来操作。

    3.1.4.2、打开存在并有内容的文件时:O_APPEND、O_TRUNC
    (1)思考一个问题:当我们打开一个已经存在并且内部有内容的文件时会怎么样?
    可能结果1:新内容会替代原来的内容(原来的内容就不见了,丢了)
    可能结果2:新内容添加在前面,原来的内容继续在后面
    可能结果3:新内容附加在后面,原来的内容还在前面
    可能结果4:不读不写的时候,原来的文件中的内容保持不变
    (2)O_TRUNC属性去打开文件时,如果这个文件中本来是有内容的,则原来的内容会被丢弃。这就对应上面的结果1
    (3)O_APPEND属性去打开文件时,如果这个文件中本来是有内容的,则新写入的内容会接续到原来内容的后面,对应结果3
    (4)默认不使用O_APPEND和O_TRUNC属性时就是结果4
    (5)如果O_APPEND和O_TRUNC同时出现会怎么样?

    3.1.4.3、exit、_exit、_Exit退出进程
    (1)当我们程序在前面步骤操作失败导致后面的操作都没有可能进行下去时,应该在前面的错误监测中结束整个程序,不应该继续让程序运行下去了。
    (2)我们如何退出程序?
    第一种;在main用return,一般原则是程序正常终止return 0,如果程序异常终止则return -1。
    第一种:正式终止进程(程序)应该使用exit或者_exit或者_Exit之一


    3.1.5.open函数的flag详解2
    3.1.5.1、打开不存在的文件时:O_CREAT、O_EXCL
    (1)思考:当我们去打开一个并不存在的文件时会怎样?当我们open打开一个文件时如果这个文件名不存在则会打开文件错误。
    (2)vi或者windows下的notepad++,都可以直接打开一个尚未存在的文件。
    (3)open的flag O_CREAT就是为了应对这种打开一个并不存在的文件的。O_CREAT就表示我们当前打开的文件并不存在,我们是要去创建并且打开它
    (4)思考:当我们open使用了O_CREAT,但是文件已经存在的情况下会怎样?结果是报错吗?
    (5)结论:open中加入O_CREAT后,不管原来这个文件存在与否都能打开成功,如果原来这个文件不存在则创建一个空的新文件,如果原来这个文件存在则会重新创建这个文件,原来的内容会被消除掉(有点类似于先删除原来的文件再创建一个新的)
    (6)这样可能带来一个问题?我们本来是想去创建一个新文件的,但是把文件名搞错了弄成了一个老文件名,结果老文件就被意外修改了。我们希望的效果是:如果我CREAT要创建的是一个已经存在的名字的文件,则给我报错,不要去创建。
    (7)这个效果就要靠O_EXCL标志和O_CREAT标志来结合使用。当这连个标志一起的时候,则没有文件时创建文件,有这个文件时会报错提醒我们。
    (8)open函数在使用O_CREAT标志去创建文件时,可以使用第三个参数mode来指定要创建的文件的权限。mode使用4个数字来指定权限的,其中后面三个很重要,对应我们要创建的这个文件的权限标志。譬如一般创建一个可读可写不可执行的文件就用0666

    3.1.5.2、O_NONBLOCK
    (1)阻塞与非阻塞。如果一个函数是阻塞式的,则我们调用这个函数时当前进程有可能被卡住(阻塞住,实质是这个函数内部要完成的事情条件不具备,当前没法做,要等待条件成熟),函数被阻塞住了就不能立刻返回如果一个函数是非阻塞式的那么我们调用这个函数后一定会立即返回,但是函数有没有完成任务不一定
    (2)阻塞和非阻塞是两种不同的设计思路,并没有好坏。总的来说,阻塞式的结果有保障但是时间没保障;非阻塞式的时间有保障但是结果没保障
    (3)操作系统提供的API和由API封装而成的库函数,有很多本身就是被设计为阻塞式或者非阻塞式的,所以我们应用程度调用这些函数的时候心里得非常清楚。
    (4)我们打开一个文件默认就是阻塞式的,如果你希望以非阻塞的方式打开文件,则flag中要加O_NONBLOCK标志
    (2)只用于设备文件,而不用于普通文件。比如说串口、IIC等都是通过文件来访问的,就存在阻塞式和非阻塞式区别。

    3.1.5.3、O_SYNC
    (1)write阻塞等待底层完成写入才返回到应用层
    (2)无O_SYNC时write只是将内容写入底层缓冲区即可返回,然后底层(操作系统中负责实现open、write这些操作的那些代码,也包含OS中读写硬盘等底层硬件的代码)在合适的时候会将buf中的内容一次性的同步到硬盘中。这种设计是为了提升硬件操作的性能和销量,提升硬件寿命;但是有时候我们希望硬件不要等待,直接将我们的内容写入硬盘中,这时候就可以用O_SYNC标志。

  • 相关阅读:
    BZOJ 1576 树剖+LCT
    CF1051D Bicolorings 递推
    CF938D Buy a Ticket dijkstra
    记一次创建svc代理失败
    K8S中Service
    K8S中的Job和CronJob
    K8S中DaemonSet
    Linux expect介绍和用法
    Java根据余弦定理计算文本相似度
    Python和Sublime的整合
  • 原文地址:https://www.cnblogs.com/zhangshenghui/p/6088972.html
Copyright © 2011-2022 走看看