当多个进程同时访问一个文件的时候,普通的write/read在执行的时候,无法保证 *** 作的原子性,可能会导致文件被污染,达不到预期的结果。
任何一个需要多个函数调用的 *** 作都不可能是原子 *** 作,因为在两个函数调用间,内核可能会将进程挂起执行另外的进程。
如果想要避免这种情况的话,则需要使用pread/pwrite函数
ssize_t pread(int fd ,void *buffer ,size_t size,off_t offset)
返回真正读取到的字节数,offset是指的从文件开始位置起的offset个字节数开始读。其余的参数与read无异。
PS:
pread是无法中断的原子 *** 作,无法中断它的定位和读取 *** 作
pread读取过后的文件偏移量不会发生改变
同理pwrite也是一样的
而在文件创建的时候也是一样的,当需要做文件创建同步的时候,我们需要在O_CREATE的时候,加上O_EXCL标志位,当已经创建过的话,会返回fd,否则返回错误
int dup( int filedes):
传入一个文件描述符,返回当前可用的最小文件描述符。
int dup2(int filedes,int filedes2):
传入文件描述符,以及新的文件描述符,如果新的文件描述符所指向的文件已经打开,则会强行将其关闭后,将该文件描述符指向到已存在的文件描述符。
如果filedes和filedes2指向同一个文件,则不做任何处理,直接返回filedes2,不会关闭文件
新返回回来的filedes2会共享filedes的文件状态标识,文件偏移量等等信息。因为它们的文件指针会指向文件表的同一个位置。只是fd不一样而已。
可以这样做:
方法1:sed -i 's/被替换的内容/要替换成的内容/' file
方法2:sed 's/被替换的内容/要替换成的内容/g' file >file.out;mv file.out file。
扩展资料:
Shell编程的常用技巧:
一、自动补齐:在linux中对于命令或路径,可以TAB键进行自动补全,以下事项需要注意:
1、只存在一个该输入字符开头的命令或路径,此时自动补全;
2、存在多个该输入字符开头的命令或路径,此时第一次点击TAB键无效,此时再次点击TAB会罗列出所有该字符开头的命令或路径,继续输入直到仅仅剩一个时自动补全;
3、如果命令已经是完整的,TAB键则是本来的移动功能;而路径的话要看命令自身的行为决定后续动作。
二、历史命令
1、history命令可以显示历史执行过的命令;
2、使用!+序号执行该序号对应的命令;
3、使用!+字符执行该字符开头的最后一次执行的指令。
三、命令别名
1、实现别名:alias ddd="df -Th";
2、删除别名:unalias ddd;
3、显示所有别名命令列表:alias;
4、存放位置:~/.bashrc (加入该文件后,重启后不会消失)。
四、重定向
1、重定向标准输入:<命令接收输入的途径由键盘改为文件;
2、重定向标准输出:>将命令的执行结果输出到指定文件,而不是直接显示到屏幕;
3、重定向标准输出:>>将命令的执行结果追加输出到指定文件;
4、重定向标准错误:2>清除指定文件的内容,并把标准错误信息保存到指定文件;
5、重定向标准错误:2>>标准错误信息追加到指定文件;
6、重定向标准输出和标准错误:&> 将标准输出、标准错误信息全部保存到指定文件,而不是直接显示在屏幕上。
-1。linux文件编程中的write函数,当写入失败时返回值为-1。Linux是一种自由和开放源代码的类UNIX *** 作系统。该 *** 作系统的内核由林纳斯·托瓦兹在1991年10月5日首次发布。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)