O_APPEND

本文转自:http://blog.csdn.net/tianwailaibin/article/details/6771667


1 O_APPEND的含义是在每次写之前,都讲标志位移动到文件的末端。表面上读这句话可能会有误解,提出一个问题:
当在O_APPEND打开后,然后用lseek移动到其他的位置,然后再用write写,这个时候,请问你数据写到哪里去了?是在末端,还是lseek移动到得位置。
答案是在末端,因为O_APPEND打开后,是一个原子操作:移动到末端,写数据。这是O_APPEND打开的作用。中间的插入时无效的。
例如 :
    int fd = open("test.txt",RDWR | O_APPEND);
    lseek(fd,10,SEEK_SET);
    if(write(fd,buffer,strlen(buffer)) !=strlen(buffer))
    {
          perror("write error");
          exit(1);
    }
     read(fd,buffer,20);
 这里lseek是没有用的,write的写入是到末端的。在write写完后,标志位是在文件末端的,这个时候的读是不会读的,所以以前的lseek是没有用的,除非你读之前再lseek一次。
  这里的read讲不会读出 任何数据,因为在末尾。它还是保持原来的写入的数据。
 
2 在read读出数据的时候,要明白一个问题。read读出的数据大部分情况下,不是以0结尾的。这样就造成了一种情况,你要输出读出数据的时候,就会出现问题,因为puts,printf函数都是以0作为输出结束符的。就出出现前面的字符是你想看到的,后面的大部分是乱码.
而对于fgets等函数,会在末尾自动加0

好的,下面是一个示例程序,可以实现标准IO中的 (r, r+, w, w+, a, a+) ,文件名由 argv[1] 传入程序,同时使用文件 IO 操作 (O_RDONLY, O_WRONLY, O_RDWR, O_CREAT, O_TRUNC, O_APPEND)。 ```c #include <stdio.h> #include <stdlib.h> #include <fcntl.h> #include <string.h> int main(int argc, char *argv[]) { if (argc != 2) { printf("Usage: %s filename\n", argv[0]); exit(1); } // 打开文件 int fd = open(argv[1], O_CREAT | O_RDWR, 0644); if (fd < 0) { perror("open file error"); exit(1); } // 测试打开方式 char mode[3]; printf("Enter mode (r, r+, w, w+, a, a+): "); scanf("%s", mode); // 根据打开方式设置文件指针位置 int whence; switch (mode[0]) { case 'r': whence = SEEK_SET; break; case 'w': whence = SEEK_SET; ftruncate(fd, 0); // 清空文件内容 break; case 'a': whence = SEEK_END; break; default: printf("Invalid mode\n"); exit(1); } // 根据打开方式设置读写权限 int oflag; switch (mode[0]) { case 'r': oflag = O_RDONLY; break; case 'w': oflag = O_WRONLY | O_TRUNC; break; case 'a': oflag = O_WRONLY | O_APPEND; break; default: printf("Invalid mode\n"); exit(1); } // 根据打开方式设置文件指针位置和读写权限 if (mode[1] == '+') { whence = SEEK_SET; oflag = O_RDWR; } // 使用文件 IO 操作打开文件 int fd2 = open(argv[1], oflag); if (fd2 < 0) { perror("open file error"); exit(1); } // 将文件指针设置到文件末尾 if (whence == SEEK_END) { lseek(fd2, 0, SEEK_END); } // 读取或写入文件内容 char buf[1024]; int n; switch (mode[0]) { case 'r': while ((n = read(fd2, buf, sizeof(buf))) > 0) { write(STDOUT_FILENO, buf, n); } break; case 'w': case 'a': while (fgets(buf, sizeof(buf), stdin) != NULL) { write(fd2, buf, strlen(buf)); } break; default: printf("Invalid mode\n"); exit(1); } // 关闭文件 close(fd); close(fd2); return 0; } ``` 你可以将上述代码保存为一个名为 `file_io.c` 的文件,然后使用以下命令编译并执行程序: ``` gcc file_io.c -o file_io ./file_io filename ``` 其中,`filename` 为你需要读写的文件名。执行程序后,根据提示输入打开方式,该程序会使用文件 IO 操作和指定的打开方式读取或写入文件内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值