This section describes the functions for performing primitive input and
output operations on file descriptors: read
, write
, and
lseek
. These functions are declared in the header file
unistd.h.
This data type is used to represent the sizes of blocks that can be read or written in a single operation. It is similar to
size_t
, but must be a signed type.
The
read
function reads up to size bytes from the file with descriptor filedes, storing the results in the buffer. (This is not necessarily a character string, and no terminating null character is added.)The return value is the number of bytes actually read. This might be less than size; for example, if there aren't that many bytes left in the file or if there aren't that many bytes immediately available. The exact behavior depends on what kind of file it is. Note that reading less than size bytes is not an error.
A value of zero indicates end-of-file (except if the value of the size argument is also zero). This is not considered an error. If you keep calling
read
while at end-of-file, it will keep returning zero and doing nothing else.If
read
returns at least one character, there is no way you can tell whether end-of-file was reached. But if you did reach the end, the next read will return zero.In case of an error,
read
returns -1. The followingerrno
error conditions are defined for this function:
EAGAIN
- Normally, when no input is immediately available,
read
waits for some input. But if theO_NONBLOCK
flag is set for the file (see File Status Flags),read
returns immediately without reading any data, and reports this error.Compatibility Note: Most versions of BSD Unix use a different error code for this:
EWOULDBLOCK
. In the GNU C Library,EWOULDBLOCK
is an alias forEAGAIN
, so it doesn't matter which name you use.On some systems, reading a large amount of data from a character special file can also fail with
EAGAIN
if the kernel cannot find enough physical memory to lock down the user's pages. This is limited to devices that transfer with direct memory access into the user's memory, which means it does not include terminals, since they always use separate buffers inside the kernel. This problem never happens on GNU/Hurd systems.Any condition that could result in
EAGAIN
can instead result in a successfulread
which returns fewer bytes than requested. Callingread
again immediately would result inEAGAIN
.EBADF
- The filedes argument is not a valid file descriptor, or is not open for reading.
EINTR
read
was interrupted by a signal while it was waiting for input. See Interrupted Primitives. A signal will not necessary causeread
to returnEINTR
; it may instead result in a successfulread
which returns fewer bytes than requested.EIO
- For many devices, and for disk files, this error code indicates a hardware error.
EIO
also occurs when a background process tries to read from the controlling terminal, and the normal action of stopping the process by sending it aSIGTTIN
signal isn't working. This might happen if the signal is being blocked or ignored, or because the process group is orphaned. See Job Control, for more information about job control, and Signal Handling, for information about signals.EINVAL
- In some systems, when reading from a character or block device, position and size offsets must be aligned to a particular block size. This error indicates that the offsets were not properly aligned.
Please note that there is no function named
read64
. This is not necessary since this function does not directly modify or handle the possibly wide file offset. Since the kernel handles this state internally, theread
function can be used for all cases.This function is a cancellation point in multi-threaded programs. This is a problem if the thread allocates some resources (like memory, file descriptors, semaphores or whatever) at the time
read
is called. If the thread gets canceled these resources stay allocated until the program ends. To avoid this, calls toread
should be protected using cancellation handlers.The
read
function is the underlying primitive for all of the functions that read from streams, such asfgetc
.
The
pread
function is similar to theread
function. The first three arguments are identical, and the return values and error codes also correspond.The difference is the fourth argument and its handling. The data block is not read from the current position of the file descriptor
filedes
. Instead the data is read from the file starting at position offset. The position of the file descriptor itself is not affected by the operation. The value is the same as before the call.When the source file is compiled with
_FILE_OFFSET_BITS == 64
thepread
function is in factpread64
and the typeoff_t
has 64 bits, which makes it possible to handle files up to 2^63 bytes in length.The return value of
pread
describes the number of bytes read. In the error case it returns -1 likeread
does and the error codes are also the same, with these additions:
EINVAL
- The value given for offset is negative and therefore illegal.
ESPIPE
- The file descriptor filedes is associate with a pipe or a FIFO and this device does not allow positioning of the file pointer.
The function is an extension defined in the Unix Single Specification version 2.
This function is similar to the
pread
function. The difference is that the offset parameter is of typeoff64_t
instead ofoff_t
which makes it possible on 32 bit machines to address files larger than 2^31 bytes and up to 2^63 bytes. The file descriptorfiledes
must be opened usingopen64
since otherwise the large offsets possible withoff64_t
will lead to errors with a descriptor in small file mode.When the source file is compiled with
_FILE_OFFSET_BITS == 64
on a 32 bit machine this function is actually available under the namepread
and so transparently replaces the 32 bit interface.
The
write
function writes up to size bytes from buffer to the file with descriptor filedes. The data in buffer is not necessarily a character string and a null character is output like any other character.The return value is the number of bytes actually written. This may be size, but can always be smaller. Your program should always call
write
in a loop, iterating until all the data is written.Once
write
returns, the data is enqueued to be written and can be read back right away, but it is not necessarily written out to permanent storage immediately. You can usefsync
when you need to be sure your data has been permanently stored before continuing. (It is more efficient for the system to batch up consecutive writes and do them all at once when convenient. Normally they will always be written to disk within a minute or less.) Modern systems provide another functionfdatasync
which guarantees integrity only for the file data and is therefore faster. You can use theO_FSYNC
open mode to makewrite
always store the data to disk before returning; see Operating Modes.In the case of an error,
write
returns -1. The followingerrno
error conditions are defined for this function:
EAGAIN
- Normally,
write
blocks until the write operation is complete. But if theO_NONBLOCK
flag is set for the file (see Control Operations), it returns immediately without writing any data and reports this error. An example of a situation that might cause the process to block on output is writing to a terminal device that supports flow control, where output has been suspended by receipt of a STOP character.Compatibility Note: Most versions of BSD Unix use a different error code for this:
EWOULDBLOCK
. In the GNU C Library,EWOULDBLOCK
is an alias forEAGAIN
, so it doesn't matter which name you use.On some systems, writing a large amount of data from a character special file can also fail with
EAGAIN
if the kernel cannot find enough physical memory to lock down the user's pages. This is limited to devices that transfer with direct memory access into the user's memory, which means it does not include terminals, since they always use separate buffers inside the kernel. This problem does not arise on GNU/Hurd systems.EBADF
- The filedes argument is not a valid file descriptor, or is not open for writing.
EFBIG
- The size of the file would become larger than the implementation can support.
EINTR
- The
write
operation was interrupted by a signal while it was blocked waiting for completion. A signal will not necessarily causewrite
to returnEINTR
; it may instead result in a successfulwrite
which writes fewer bytes than requested. See Interrupted Primitives.EIO
- For many devices, and for disk files, this error code indicates a hardware error.
ENOSPC
- The device containing the file is full.
EPIPE
- This error is returned when you try to write to a pipe or FIFO that isn't open for reading by any process. When this happens, a
SIGPIPE
signal is also sent to the process; see Signal Handling.EINVAL
- In some systems, when writing to a character or block device, position and size offsets must be aligned to a particular block size. This error indicates that the offsets were not properly aligned.
Unless you have arranged to prevent
EINTR
failures, you should checkerrno
after each failing call towrite
, and if the error wasEINTR
, you should simply repeat the call. See Interrupted Primitives. The easy way to do this is with the macroTEMP_FAILURE_RETRY
, as follows:nbytes = TEMP_FAILURE_RETRY (write (desc, buffer, count));Please note that there is no function named
write64
. This is not necessary since this function does not directly modify or handle the possibly wide file offset. Since the kernel handles this state internally thewrite
function can be used for all cases.This function is a cancellation point in multi-threaded programs. This is a problem if the thread allocates some resources (like memory, file descriptors, semaphores or whatever) at the time
write
is called. If the thread gets canceled these resources stay allocated until the program ends. To avoid this, calls towrite
should be protected using cancellation handlers.The
write
function is the underlying primitive for all of the functions that write to streams, such asfputc
.
The
pwrite
function is similar to thewrite
function. The first three arguments are identical, and the return values and error codes also correspond.The difference is the fourth argument and its handling. The data block is not written to the current position of the file descriptor
filedes
. Instead the data is written to the file starting at position offset. The position of the file descriptor itself is not affected by the operation. The value is the same as before the call.When the source file is compiled with
_FILE_OFFSET_BITS == 64
thepwrite
function is in factpwrite64
and the typeoff_t
has 64 bits, which makes it possible to handle files up to 2^63 bytes in length.The return value of
pwrite
describes the number of written bytes. In the error case it returns -1 likewrite
does and the error codes are also the same, with these additions:
EINVAL
- The value given for offset is negative and therefore illegal.
ESPIPE
- The file descriptor filedes is associated with a pipe or a FIFO and this device does not allow positioning of the file pointer.
The function is an extension defined in the Unix Single Specification version 2.
This function is similar to the
pwrite
function. The difference is that the offset parameter is of typeoff64_t
instead ofoff_t
which makes it possible on 32 bit machines to address files larger than 2^31 bytes and up to 2^63 bytes. The file descriptorfiledes
must be opened usingopen64
since otherwise the large offsets possible withoff64_t
will lead to errors with a descriptor in small file mode.When the source file is compiled using
_FILE_OFFSET_BITS == 64
on a 32 bit machine this function is actually available under the namepwrite
and so transparently replaces the 32 bit interface.