- File descriptor
In computer programming, a file descriptor is an abstract key for accessing a file. The term is generally used in
POSIX operating system s. InMicrosoft Windows terminology and in the context of the C standard I/O library, "file handle" is preferred, though the latter case is technically a different object (see below).In POSIX, a file descriptor is an
integer , specifically of the C type int. There are 3 standard POSIX file descriptors which presumably every process (save perhaps a daemon) should expect to have:Generally, a file descriptor is an index for an entry in a kernel-resident data structure containing the details of all open files. In POSIX this data structure is called a file descriptor table, and each process has its own file descriptor table. The user application passes the abstract key to the kernel through a
system call , and the kernel will access the file on behalf of the application, based on the key. The application itself cannot read or write the file descriptor table directly.In
Unix-like systems, file descriptors can refer to files, directories, block orcharacter device s (also called "special files"),socket s,FIFO s (also callednamed pipe s), or unnamed pipes.The FILE * file handle in the C standard I/O library routines is technically a pointer to a data structure managed by those library routines; one of those structures usually includes an actual low level file descriptor for the object in question on Unix-like systems. Since "file handle" refers to this additional layer, it is not interchangeable with "file descriptor".
To further complicate terminology,
Microsoft Windows also uses the term "file handle" to refer to the more low-level construct, akin to POSIX's file descriptors. Microsoft's C libraries also provide compatibility functions which "wrap" these native handles to support the POSIX-like convention of integer file descriptors as detailed above.Operations on file descriptors
A modern Unix typically provides the following operations on file descriptor
Creating file descriptors
* open(), open64(), creat(), creat64()
* socket()
* socketpair()
* pipe()Deriving file descriptors
* dirfd()
* fileno()Operations on a single file descriptor
* read(), write()
* readv(), writev()
* pread(), pwrite()
* recv(), send()
* recvmsg(), sendmsg() (inc. allowing sending FDs)
* sendfile()
* lseek(), lseek64()
* fstat(), fstat64()
* fchmod()
* fchown()
* fdopen()
* gzdopen()
* ftruncate()
* fsync()
* fdatasync()
* fstatvfs()Operations on multiple file descriptors
* select(), pselect()
* poll(), epoll()Operations on the file descriptor table
* close()
* dup(): duplicates an existing file descriptor guaranteeing to be the lowest number available file descriptor
* dup2(): the new file descriptor will have the value passed as an argument
* fcntl (F_DUPFD)
* fcntl (F_GETFD and F_SETFD)Operations that modify process state
* fchdir(): sets the process's current working directory based on a directory file descriptor
* mmap(): maps ranges of a file into the process's address spaceFile locking
* flock()
* fcntl (F_GETLK, F_SETLK and F_SETLKW)
* lockf()ockets
* connect()
* bind()
* listen()
* accept(): creates a new file descriptor for an incoming connection
* getsockname()
* getpeername()
* getsockopt(), setsockopt()
* shutdown(): shuts down one or both halves of a full duplex connectionMiscellaneous
* ioctl(): a large collection of miscellaneous operations on a single file descriptor, often associated with a device
Upcoming operations
A series of new operations on file descriptors has been added to Solaris and Linux, as well as numerous C libraries, to be standardized in a future version of
POSIX . [cite book
title = Extended API Set, Part 2
publisher = The Open Group
date = Oct 2006
url = http://www.opengroup.org/bookstore/catalog/c063.htm
isbn = 1931624674] Theat
suffix signifies that the function takes an additional first argument supplying a file descriptor from whichrelative path s are resolved, the forms lacking theat
suffix thus becoming equivalent to passing a file descriptor corresponding to the currentworking directory .* openat()
* faccessat()
* fchmodat()
* fchownat()
* fstatat()
* futimesat()
* linkat()
* mkdirat()
* mknodat()
* readlinkat()
* renameat()
* symlinkat()
* unlinkat()
* mkfifoat()
* fdopendir()The
Native API of theWindows NT family of operating systems also allows callers to specify aroot directory when they open a file or other object by name. [ [http://msdn2.microsoft.com/library/ms804358.aspx ZwCreateFile] in MSDN Library]File descriptors as capabilities
Unix file descriptors are capabilities. They can be passed between processes across
Unix domain socket s using thesendmsg () system call.A Unix process' file descriptor table is an example of a C-list.
References
Wikimedia Foundation. 2010.