zoukankan      html  css  js  c++  java
  • O_APPEND的含义

    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
    原文:http://blog.chinaunix.net/space.php?uid=21377953&do=blog&id=443339
  • 相关阅读:
    IE 11 使用 flexbox 垂直居中 bug
    Electron build 无法下载 winCodeSign 等资源
    Electron 开发环境下总是 crash
    解决 Electron 包下载太慢问题
    Netty--数据通信和心跳检测
    Netty编解码技术和UDP实现
    Netty入门
    Java 网络IO编程(BIO、NIO、AIO)
    java.util.concurrent常用类(CountDownLatch,Semaphore,CyclicBarrier,Future)
    JDK多任务执行框架(Executor框架)
  • 原文地址:https://www.cnblogs.com/ymy124/p/2343656.html
Copyright © 2011-2022 走看看