Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1047913
  • 博文数量: 297
  • 博客积分: 11721
  • 博客等级: 上将
  • 技术积分: 3431
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-25 10:21
文章分类

全部博文(297)

文章存档

2016年(9)

2011年(71)

2010年(137)

2009年(80)

分类: LINUX

2010-03-01 13:01:28

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
阅读(1137) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~