close (system call)

A close system call is a system call used to close a file descriptor by the kernel. For most file systems, a program terminates access to a file in a filesystem using the close system call. This flushes file buffers, updates file metadata, which may include and end-of-file indicator in the data; de-allocates resources associated with the file (including the file descriptor) and updates the system wide table of files in use. Some programming languages maintain a data structure of files opened by their runtime library and may close when the program terminates. This practice is known as resource acquisition is initialization (RAII). Some operating systems will invoke the close on files held by a program if it terminates. Some operating systems will invoke the close syscall as part of an operating system recovery as a result of a system failure.

C library POSIX definition

The close call is standardized by the POSIX specification

int close  (int filedes);
int fclose (FILE *stream);

The function returns zero to indicate the file was closed successfully. If any error occurs, a value of -1 is returned and errno is appropriately set.

The errors that can occur include:

EBADF
The argument supplied was not a valid file descriptor
EINTR
The function call was interrupted by a signal
EIO
An I/O error occurred
gollark: I mean, I like it *generally*, but seriously why.
gollark: It's easy to use at the cost of apioidal weirdness, thus kind of bad in some ways.
gollark: It errors, *but the list thing is appended to anyway*!
gollark: There is also extreme weirdness with, er, `x = ([], [])x[0] += ["bees"]`.
gollark: Which can have some unexpected results.

References

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.