read (system call)
In most modern operating systems, a program that needs to access data from a file stored in a file system uses the read system call. The file is identified by the file descriptor that is obtained from a previous call to open. This system call reads data, in bytes as specified by the caller, from the file and stores then into a buffer supplied by the calling process.
The read system call can take three arguments:
- The file descriptor of the file,
- the buffer where the read data is to be stored and
- the number of bytes to be read from the file.
The read system call interface is standardized by the POSIX specification. Data from a file is read by calling the read function:
ssize_t read(int fd, void *buf, size_t count);
The value returned is the number of bytes read (zero indicates end of file) and the file position is advanced by this number. It is not an error if this number is smaller than the number of bytes requested; this may happen for example because fewer bytes are actually available right now (maybe because we were close to end-of-file, or because we are reading from a pipe, or from a terminal), or because the system call was interrupted by a signal.
Alternatively. -1 is returned when an error occurs, in such a case errno is set appropriately and it is left unspecified whether the file position (if any) changes.