Linux系统编程中O_APPEND和O_TRUNC标志的使用方法。

简介: 大家好! 今天主要和大家聊一聊,open函数的的flags标志,譬如​:O_APPEND和O_TRUNC标志的使用方法。

8635abdb772613d38a89cfe388ff2c61.png

第一:O_TRUNC标志使用方法

      使用该标志O_TRUNC的时候,调用open函数打开文件的时候会将文件原本的内容全部丢弃,文件大小变为0;下面对文件的操作代码如下:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#icclude <stdlib.h>
int main(void)
{
 int fd;
 /* 打开文件 */
 fd = open("./test_file", O_WRONLY | O_TRUNC);
 if (-1 == fd) {
 perror("open error");
 exit(-1);
 }
 /* 关闭文件 */
 close(fd);
 exit(0);
}

在当前目录下有一个文件test_file,测试代码中使用了O_TRUNC标志打开该文件,代码中仅仅只是打开文件,并没有对其进行读写操作,接下来编译运行来看看测试结果;

a6246d3a27699302e6844c0684d53b12.png

第二:O_APPEND使用方法

   接下来聊一聊,使用O_APPEND标志方法,如果open函数携带并使用了O_APPEND标志,调用open函数打开文件,当每次使用write()函数对文件进行读写操作时,都会自动把文件当前位置偏移量移动到文件末尾,从文件末尾开始写入数据,也就是意味着每次写入数据都是从文件末尾开始。这里我们直接进行测试,测试代码如下所示:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(void)
{
   char buffer[16];
   int fd;
   int ret;
/* 打开文件 */
 fd = open("./test_file", O_RDWR | O_APPEND);
 if (-1 == fd) {
 perror("open error");
 exit(-1);
 }
 /* 初始化 buffer 中的数据 */
 memset(buffer, 0x55, sizeof(buffer));
 /* 写入数据: 写入 4 个字节数据 */
 ret = write(fd, buffer, 4);
 if (-1 == ret) {
 perror("write error");
 goto err;
 }
 /* 将 buffer 缓冲区中的数据全部清 0 */
 memset(buffer, 0x00, sizeof(buffer));
 /* 将位置偏移量移动到距离文件末尾 4 个字节处 */
 ret = lseek(fd, -4, SEEK_END);
 if (-1 == ret) {
 perror("lseek error");
 goto err;
 }
 //读取数据
 ret=read(fd,buffer,4);
 if(-1==ret)
 {
    perror("read error");
    goto err;
 }
printf("0x%x 0x%x 0x%x 0x%x\n", buffer[0], buffer[1],buffer[2], buffer[3]);
    ret = 0;
err:
 /* 关闭文件 */
 close(fd);
 exit(ret);  
}

测试代码中会去打开当前目录下的 test_file 文件,使用可读可写方式,并且使用了 O_APPEND 标志,前面笔者给大家提到过,open 打开一个文件,默认的读写位置偏移量会处于文件头,但测试代码中使用了O_APPEND 标志,如果 O_APPEND 确实能生效的话,也就意味着调用 write 函数会从文件末尾开始写;代码中写入了 4 个字节数据,都是 0x55,之后,使用 lseek 函数将位置偏移量移动到距离文件末尾 4 个字节处,读取 4 个字节(也就是读取文件最后 4 个字节数据),之后将其打印出来,如果上面笔者的描述正确的话,打印出来的数据就是我们写入的数据,如果 O_APPEND 不能生效,则打印出来数据就不会是 0x55,接下来编译测试:

5651d9af4d6a7020783fd26173084f8a.png

总结:O_TRUNC和O_APPEND标志,在特殊的情况下,使用起来非常方便,其中,使用了O_APPEND标志后,即使通过lseek函数也是无法修改写文件的对应的偏移量的。

目录
相关文章
|
2天前
|
Linux Shell
Linux系统文件默认权限
Linux系统文件默认权限
13 2
|
1天前
|
设计模式 Unix Linux
Linux系统命令技巧
Linux系统命令技巧
12 3
|
2天前
|
Linux Shell
Linux系统
是对Linux系统进行管理的命令。对于Linux系统来说,无论是中央处理器、内存、磁盘驱动器、键盘、鼠标,还是用户等都是文件,Linux系统管理的命令是它正常运行的核心,与之前的DOS命令类似。linux命令在系统中有两种类型:内置Shell命令和Linux命令。
|
3天前
|
存储 Oracle Unix
Linux 系统目录结构
Linux 系统目录结构
12 2
|
1天前
|
监控 Linux 测试技术
Linux系统命令与网络,磁盘和日志监控总结
Linux系统命令与网络,磁盘和日志监控总结
11 0
|
1天前
|
监控 Linux 测试技术
Linux系统命令与网络,磁盘和日志监控三
Linux系统命令与网络,磁盘和日志监控三
9 0
|
2天前
|
Linux Shell
Linux系统
是对Linux系统进行管理的命令。对于Linux系统来说,无论是中央处理器、内存、磁盘驱动器、键盘、鼠标,还是用户等都是文件,Linux系统管理的命令是它正常运行的核心,与之前的DOS命令类似。linux命令在系统中有两种类型:内置Shell命令和Linux命令。
|
5月前
|
NoSQL Unix Linux
Linux下的系统编程——守护进程、线程(十二)
Linux下的系统编程——守护进程、线程(十二)
63 0
Linux下的系统编程——守护进程、线程(十二)
|
5月前
|
存储 Linux Shell
Linux系统编程(守护进程)
Linux系统编程(守护进程)
63 0
|
NoSQL Ubuntu Unix
linux系统编程(十)守护进程、线程(上)
linux系统编程(十)守护进程、线程
267 0
linux系统编程(十)守护进程、线程(上)