文档对此相当模糊。如果我多次调用C的read()函数,则必须传递希望每次读取的字节数。但是我怎么知道起始指数是什么呢?例如:
n = read(fd, *buffer, 10) n2 = read(fd, *buffer, 10)
对read的第一次调用将使用文件描述符fd将文件的10个字节读入buffer。但是当我再次调用它时,它是读取完全相同的东西,还是读取接下来的10个字节?我不认为这是有意义的,但我看不出有什么办法来定义一个理想的开始指数。
发布于 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
复制相似问题