文档对此相当模糊。如果我多次调用C的read()函数,则必须传递希望每次读取的字节数。但是我怎么知道起始指数是什么呢?例如:
n = read(fd, *buffer, 10) n2 = read(fd, *buffer, 10)
对read的第一次调用将使用文件描述符fd将文件的10个字节读入buffer。但是当我再次调用它时,它是读取完全相同的东西,还是读取接下来的10个字节?我不认为这是有意义的,但我看不出有什么办法来定义一个理想的开始指数。
发布于 2016-01-19 01:52:00
操作系统跟踪文件中的“当前位置”。打开文件时,这将是文件的开始。每次调用read时,都会从当前位置读取一些字节,并提升当前位置。您可以使用lseek更改当前位置。
注意,read也适用于没有当前位置的东西,比如管道和套接字。因为读取这些数据总是会返回下一段尚未阅读的数据,这使得它们与文件的工作方式保持一致(除了不能使用lseek)。
发布于 2016-01-19 01:48:17
read(fd, buf, len)函数将推进存储在fd通过len引用的文件描述中的偏移量。每次调用read或write时,都会在该偏移量处执行操作,然后偏移量将增加。您可以使用lseek()手动重新定位偏移量,具体取决于fd引用的文件类型。
还有一对函数pread()和pwrite()不修改此偏移量,而是必须显式地将偏移量传递给函数。请注意,对于Linux上的pwrite(),O_APPEND是坏的。
欲知更多细节,请阅读IEEE 1003.1,2013年版(POSIX.1,2008年)对读()的评论。
https://stackoverflow.com/questions/34867211
复制相似问题