Chinaunix首页 | 论坛 | 博客
  • 博客访问: 755069
  • 博文数量: 130
  • 博客积分: 2951
  • 博客等级: 少校
  • 技术积分: 1875
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-04 18:32
文章分类

全部博文(130)

文章存档

2013年(1)

2012年(129)

分类: C/C++

2012-10-24 14:52:31

O_APPEND被设置时候,write操作会先seek到文件末尾,然后写入,读的时候则当前seek在哪就在哪读,
比如文件1.txt
#cat 1.txt
abcd

  1. #o_append.c
  2. #include
    #include

    int main(int ac, char * av[])
    {
            int fd;
            char buf[] = "1234567";
            off_t currpos;
            int s;

            if((fd=open(av[1], O_RDWR))==-1)
                    perror("open error");

            s = fcntl(fd, F_GETFL);
            s |= O_APPEND;
            if(fcntl(fd, F_SETFL, s) == -1)
                    perror("set flag error");

            if(lseek(fd, 0, SEEK_SET) == -1) //虽然这里把文件定位到开始处
                    perror("lseek error");

            if(write(fd, buf, strlen(buf)) != strlen(buf)) //但是写后发现仍然被写到文件末尾
                    perror("write error");

            currpos = lseek(fd, 0, SEEK_CUR); //获得当前seek的位置,可以看到已经是文件末尾
            printf("currpos = %d\n", currpos);

            if(lseek(fd, 0, SEEK_SET) == -1) //再次seek到开始处
                    perror("lseek error");

            if(read(fd, buf, strlen(buf)) != strlen(buf)) //从开始处读入数据
                    perror("read error");

            printf("read buf = %s\n", buf);

            close(fd);
            exit(0);

    }
O_APPEND的出现实际上是为了解决以前多个进程对同一文件写操作时候,lseek和write是分开进行的,这样在移动文件指针和写之间进程有可能被切换,从而导致文件内容被意外覆盖等等错误。O_APPEND告诉write操作,写之前要移动文件指针到文件末尾,这成为了一个原子操作,从而不会被打断。

阅读(3745) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~