mirror of git://sourceware.org/git/glibc.git
				
				
				
			
		
			
				
	
	
		
			396 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			396 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
@node I/O Overview, I/O on Streams, Pattern Matching, Top
 | 
						|
@c %MENU% Introduction to the I/O facilities
 | 
						|
@chapter Input/Output Overview
 | 
						|
 | 
						|
Most programs need to do either input (reading data) or output (writing
 | 
						|
data), or most frequently both, in order to do anything useful.  @Theglibc{}
 | 
						|
provides such a large selection of input and output functions
 | 
						|
that the hardest part is often deciding which function is most
 | 
						|
appropriate!
 | 
						|
 | 
						|
This chapter introduces concepts and terminology relating to input
 | 
						|
and output.  Other chapters relating to the GNU I/O facilities are:
 | 
						|
 | 
						|
@itemize @bullet
 | 
						|
@item
 | 
						|
@ref{I/O on Streams}, which covers the high-level functions
 | 
						|
that operate on streams, including formatted input and output.
 | 
						|
 | 
						|
@item
 | 
						|
@ref{Low-Level I/O}, which covers the basic I/O and control
 | 
						|
functions on file descriptors.
 | 
						|
 | 
						|
@item
 | 
						|
@ref{File System Interface}, which covers functions for operating on
 | 
						|
directories and for manipulating file attributes such as access modes
 | 
						|
and ownership.
 | 
						|
 | 
						|
@item
 | 
						|
@ref{Pipes and FIFOs}, which includes information on the basic interprocess
 | 
						|
communication facilities.
 | 
						|
 | 
						|
@item
 | 
						|
@ref{Sockets}, which covers a more complicated interprocess communication
 | 
						|
facility with support for networking.
 | 
						|
 | 
						|
@item
 | 
						|
@ref{Low-Level Terminal Interface}, which covers functions for changing
 | 
						|
how input and output to terminals or other serial devices are processed.
 | 
						|
@end itemize
 | 
						|
 | 
						|
 | 
						|
@menu
 | 
						|
* I/O Concepts::       Some basic information and terminology.
 | 
						|
* File Names::         How to refer to a file.
 | 
						|
@end menu
 | 
						|
 | 
						|
@node I/O Concepts, File Names,  , I/O Overview
 | 
						|
@section Input/Output Concepts
 | 
						|
 | 
						|
Before you can read or write the contents of a file, you must establish
 | 
						|
a connection or communications channel to the file.  This process is
 | 
						|
called @dfn{opening} the file.  You can open a file for reading, writing,
 | 
						|
or both.
 | 
						|
@cindex opening a file
 | 
						|
 | 
						|
The connection to an open file is represented either as a stream or as a
 | 
						|
file descriptor.  You pass this as an argument to the functions that do
 | 
						|
the actual read or write operations, to tell them which file to operate
 | 
						|
on.  Certain functions expect streams, and others are designed to
 | 
						|
operate on file descriptors.
 | 
						|
 | 
						|
When you have finished reading from or writing to the file, you can
 | 
						|
terminate the connection by @dfn{closing} the file.  Once you have
 | 
						|
closed a stream or file descriptor, you cannot do any more input or
 | 
						|
output operations on it.
 | 
						|
 | 
						|
@menu
 | 
						|
* Streams and File Descriptors::    The GNU C Library provides two ways
 | 
						|
			             to access the contents of files.
 | 
						|
* File Position::                   The number of bytes from the
 | 
						|
                                     beginning of the file.
 | 
						|
@end menu
 | 
						|
 | 
						|
@node Streams and File Descriptors, File Position,  , I/O Concepts
 | 
						|
@subsection Streams and File Descriptors
 | 
						|
 | 
						|
When you want to do input or output to a file, you have a choice of two
 | 
						|
basic mechanisms for representing the connection between your program
 | 
						|
and the file: file descriptors and streams.  File descriptors are
 | 
						|
represented as objects of type @code{int}, while streams are represented
 | 
						|
as @code{FILE *} objects.
 | 
						|
 | 
						|
File descriptors provide a primitive, low-level interface to input and
 | 
						|
output operations.  Both file descriptors and streams can represent a
 | 
						|
connection to a device (such as a terminal), or a pipe or socket for
 | 
						|
communicating with another process, as well as a normal file.  But, if
 | 
						|
you want to do control operations that are specific to a particular kind
 | 
						|
of device, you must use a file descriptor; there are no facilities to
 | 
						|
use streams in this way.  You must also use file descriptors if your
 | 
						|
program needs to do input or output in special modes, such as
 | 
						|
nonblocking (or polled) input (@pxref{File Status Flags}).
 | 
						|
 | 
						|
Streams provide a higher-level interface, layered on top of the
 | 
						|
primitive file descriptor facilities.  The stream interface treats all
 | 
						|
kinds of files pretty much alike---the sole exception being the three
 | 
						|
styles of buffering that you can choose (@pxref{Stream Buffering}).
 | 
						|
 | 
						|
The main advantage of using the stream interface is that the set of
 | 
						|
functions for performing actual input and output operations (as opposed
 | 
						|
to control operations) on streams is much richer and more powerful than
 | 
						|
the corresponding facilities for file descriptors.  The file descriptor
 | 
						|
interface provides only simple functions for transferring blocks of
 | 
						|
characters, but the stream interface also provides powerful formatted
 | 
						|
input and output functions (@code{printf} and @code{scanf}) as well as
 | 
						|
functions for character- and line-oriented input and output.
 | 
						|
@c !!! glibc has dprintf, which lets you do printf on an fd.
 | 
						|
 | 
						|
Since streams are implemented in terms of file descriptors, you can
 | 
						|
extract the file descriptor from a stream and perform low-level
 | 
						|
operations directly on the file descriptor.  You can also initially open
 | 
						|
a connection as a file descriptor and then make a stream associated with
 | 
						|
that file descriptor.
 | 
						|
 | 
						|
In general, you should stick with using streams rather than file
 | 
						|
descriptors, unless there is some specific operation you want to do that
 | 
						|
can only be done on a file descriptor.  If you are a beginning
 | 
						|
programmer and aren't sure what functions to use, we suggest that you
 | 
						|
concentrate on the formatted input functions (@pxref{Formatted Input})
 | 
						|
and formatted output functions (@pxref{Formatted Output}).
 | 
						|
 | 
						|
If you are concerned about portability of your programs to systems other
 | 
						|
than GNU, you should also be aware that file descriptors are not as
 | 
						|
portable as streams.  You can expect any system running @w{ISO C} to
 | 
						|
support streams, but @nongnusystems{} may not support file descriptors at
 | 
						|
all, or may only implement a subset of the GNU functions that operate on
 | 
						|
file descriptors.  Most of the file descriptor functions in @theglibc{}
 | 
						|
are included in the POSIX.1 standard, however.
 | 
						|
 | 
						|
@node File Position,  , Streams and File Descriptors, I/O Concepts
 | 
						|
@subsection File Position
 | 
						|
 | 
						|
One of the attributes of an open file is its @dfn{file position} that
 | 
						|
keeps track of where in the file the next character is to be read or
 | 
						|
written.  On @gnusystems{}, and all POSIX.1 systems, the file position
 | 
						|
is simply an integer representing the number of bytes from the beginning
 | 
						|
of the file.
 | 
						|
 | 
						|
The file position is normally set to the beginning of the file when it
 | 
						|
is opened, and each time a character is read or written, the file
 | 
						|
position is incremented.  In other words, access to the file is normally
 | 
						|
@dfn{sequential}.
 | 
						|
@cindex file position
 | 
						|
@cindex sequential-access files
 | 
						|
 | 
						|
Ordinary files permit read or write operations at any position within
 | 
						|
the file.  Some other kinds of files may also permit this.  Files which
 | 
						|
do permit this are sometimes referred to as @dfn{random-access} files.
 | 
						|
You can change the file position using the @code{fseek} function on a
 | 
						|
stream (@pxref{File Positioning}) or the @code{lseek} function on a file
 | 
						|
descriptor (@pxref{I/O Primitives}).  If you try to change the file
 | 
						|
position on a file that doesn't support random access, you get the
 | 
						|
@code{ESPIPE} error.
 | 
						|
@cindex random-access files
 | 
						|
 | 
						|
Streams and descriptors that are opened for @dfn{append access} are
 | 
						|
treated specially for output: output to such files is @emph{always}
 | 
						|
appended sequentially to the @emph{end} of the file, regardless of the
 | 
						|
file position.  However, the file position is still used to control where in
 | 
						|
the file reading is done.
 | 
						|
@cindex append-access files
 | 
						|
 | 
						|
If you think about it, you'll realize that several programs can read a
 | 
						|
given file at the same time.  In order for each program to be able to
 | 
						|
read the file at its own pace, each program must have its own file
 | 
						|
pointer, which is not affected by anything the other programs do.
 | 
						|
 | 
						|
In fact, each opening of a file creates a separate file position.
 | 
						|
Thus, if you open a file twice even in the same program, you get two
 | 
						|
streams or descriptors with independent file positions.
 | 
						|
 | 
						|
By contrast, if you open a descriptor and then duplicate it to get
 | 
						|
another descriptor, these two descriptors share the same file position:
 | 
						|
changing the file position of one descriptor will affect the other.
 | 
						|
 | 
						|
@node File Names,  , I/O Concepts, I/O Overview
 | 
						|
@section File Names
 | 
						|
 | 
						|
In order to open a connection to a file, or to perform other operations
 | 
						|
such as deleting a file, you need some way to refer to the file.  Nearly
 | 
						|
all files have names that are strings---even files which are actually
 | 
						|
devices such as tape drives or terminals.  These strings are called
 | 
						|
@dfn{file names}.  You specify the file name to say which file you want
 | 
						|
to open or operate on.
 | 
						|
 | 
						|
This section describes the conventions for file names and how the
 | 
						|
operating system works with them.
 | 
						|
@cindex file name
 | 
						|
 | 
						|
@menu
 | 
						|
* Directories::                 Directories contain entries for files.
 | 
						|
* File Name Resolution::        A file name specifies how to look up a file.
 | 
						|
* File Name Errors::            Error conditions relating to file names.
 | 
						|
* File Name Portability::       File name portability and syntax issues.
 | 
						|
@end menu
 | 
						|
 | 
						|
 | 
						|
@node Directories, File Name Resolution,  , File Names
 | 
						|
@subsection Directories
 | 
						|
 | 
						|
In order to understand the syntax of file names, you need to understand
 | 
						|
how the file system is organized into a hierarchy of directories.
 | 
						|
 | 
						|
@cindex directory
 | 
						|
@cindex link
 | 
						|
@cindex directory entry
 | 
						|
A @dfn{directory} is a file that contains information to associate other
 | 
						|
files with names; these associations are called @dfn{links} or
 | 
						|
@dfn{directory entries}.  Sometimes, people speak of ``files in a
 | 
						|
directory'', but in reality, a directory only contains pointers to
 | 
						|
files, not the files themselves.
 | 
						|
 | 
						|
@cindex file name component
 | 
						|
The name of a file contained in a directory entry is called a @dfn{file
 | 
						|
name component}.  In general, a file name consists of a sequence of one
 | 
						|
or more such components, separated by the slash character (@samp{/}).  A
 | 
						|
file name which is just one component names a file with respect to its
 | 
						|
directory.  A file name with multiple components names a directory, and
 | 
						|
then a file in that directory, and so on.
 | 
						|
 | 
						|
Some other documents, such as the POSIX standard, use the term
 | 
						|
@dfn{pathname} for what we call a file name, and either @dfn{filename}
 | 
						|
or @dfn{pathname component} for what this manual calls a file name
 | 
						|
component.  We don't use this terminology because a ``path'' is
 | 
						|
something completely different (a list of directories to search), and we
 | 
						|
think that ``pathname'' used for something else will confuse users.  We
 | 
						|
always use ``file name'' and ``file name component'' (or sometimes just
 | 
						|
``component'', where the context is obvious) in GNU documentation.  Some
 | 
						|
macros use the POSIX terminology in their names, such as
 | 
						|
@code{PATH_MAX}.  These macros are defined by the POSIX standard, so we
 | 
						|
cannot change their names.
 | 
						|
 | 
						|
You can find more detailed information about operations on directories
 | 
						|
in @ref{File System Interface}.
 | 
						|
 | 
						|
@node File Name Resolution, File Name Errors, Directories, File Names
 | 
						|
@subsection File Name Resolution
 | 
						|
 | 
						|
A file name consists of file name components separated by slash
 | 
						|
(@samp{/}) characters.  On the systems that @theglibc{} supports,
 | 
						|
multiple successive @samp{/} characters are equivalent to a single
 | 
						|
@samp{/} character.
 | 
						|
 | 
						|
@cindex file name resolution
 | 
						|
The process of determining what file a file name refers to is called
 | 
						|
@dfn{file name resolution}.  This is performed by examining the
 | 
						|
components that make up a file name in left-to-right order, and locating
 | 
						|
each successive component in the directory named by the previous
 | 
						|
component.  Of course, each of the files that are referenced as
 | 
						|
directories must actually exist, be directories instead of regular
 | 
						|
files, and have the appropriate permissions to be accessible by the
 | 
						|
process; otherwise the file name resolution fails.
 | 
						|
 | 
						|
@cindex root directory
 | 
						|
@cindex absolute file name
 | 
						|
If a file name begins with a @samp{/}, the first component in the file
 | 
						|
name is located in the @dfn{root directory} of the process (usually all
 | 
						|
processes on the system have the same root directory).  Such a file name
 | 
						|
is called an @dfn{absolute file name}.
 | 
						|
@c !!! xref here to chroot, if we ever document chroot. -rm
 | 
						|
 | 
						|
@cindex relative file name
 | 
						|
Otherwise, the first component in the file name is located in the
 | 
						|
current working directory (@pxref{Working Directory}).  This kind of
 | 
						|
file name is called a @dfn{relative file name}.
 | 
						|
 | 
						|
@cindex parent directory
 | 
						|
The file name components @file{.} (``dot'') and @file{..} (``dot-dot'')
 | 
						|
have special meanings.  Every directory has entries for these file name
 | 
						|
components.  The file name component @file{.} refers to the directory
 | 
						|
itself, while the file name component @file{..} refers to its
 | 
						|
@dfn{parent directory} (the directory that contains the link for the
 | 
						|
directory in question).  As a special case, @file{..} in the root
 | 
						|
directory refers to the root directory itself, since it has no parent;
 | 
						|
thus @file{/..} is the same as @file{/}.
 | 
						|
 | 
						|
Here are some examples of file names:
 | 
						|
 | 
						|
@table @file
 | 
						|
@item /a
 | 
						|
The file named @file{a}, in the root directory.
 | 
						|
 | 
						|
@item /a/b
 | 
						|
The file named @file{b}, in the directory named @file{a} in the root directory.
 | 
						|
 | 
						|
@item a
 | 
						|
The file named @file{a}, in the current working directory.
 | 
						|
 | 
						|
@item /a/./b
 | 
						|
This is the same as @file{/a/b}.
 | 
						|
 | 
						|
@item ./a
 | 
						|
The file named @file{a}, in the current working directory.
 | 
						|
 | 
						|
@item ../a
 | 
						|
The file named @file{a}, in the parent directory of the current working
 | 
						|
directory.
 | 
						|
@end table
 | 
						|
 | 
						|
@c An empty string may ``work'', but I think it's confusing to
 | 
						|
@c try to describe it.  It's not a useful thing for users to use--rms.
 | 
						|
A file name that names a directory may optionally end in a @samp{/}.
 | 
						|
You can specify a file name of @file{/} to refer to the root directory,
 | 
						|
but the empty string is not a meaningful file name.  If you want to
 | 
						|
refer to the current working directory, use a file name of @file{.} or
 | 
						|
@file{./}.
 | 
						|
 | 
						|
Unlike some other operating systems, @gnusystems{} don't have any
 | 
						|
built-in support for file types (or extensions) or file versions as part
 | 
						|
of its file name syntax.  Many programs and utilities use conventions
 | 
						|
for file names---for example, files containing C source code usually
 | 
						|
have names suffixed with @samp{.c}---but there is nothing in the file
 | 
						|
system itself that enforces this kind of convention.
 | 
						|
 | 
						|
@node File Name Errors, File Name Portability, File Name Resolution, File Names
 | 
						|
@subsection File Name Errors
 | 
						|
 | 
						|
@cindex file name errors
 | 
						|
@cindex usual file name errors
 | 
						|
 | 
						|
Functions that accept file name arguments usually detect these
 | 
						|
@code{errno} error conditions relating to the file name syntax or
 | 
						|
trouble finding the named file.  These errors are referred to throughout
 | 
						|
this manual as the @dfn{usual file name errors}.
 | 
						|
 | 
						|
@table @code
 | 
						|
@item EACCES
 | 
						|
The process does not have search permission for a directory component
 | 
						|
of the file name.
 | 
						|
 | 
						|
@item ENAMETOOLONG
 | 
						|
This error is used when either the total length of a file name is
 | 
						|
greater than @code{PATH_MAX}, or when an individual file name component
 | 
						|
has a length greater than @code{NAME_MAX}.  @xref{Limits for Files}.
 | 
						|
 | 
						|
On @gnuhurdsystems{}, there is no imposed limit on overall file name
 | 
						|
length, but some file systems may place limits on the length of a
 | 
						|
component.
 | 
						|
 | 
						|
@item ENOENT
 | 
						|
This error is reported when a file referenced as a directory component
 | 
						|
in the file name doesn't exist, or when a component is a symbolic link
 | 
						|
whose target file does not exist.  @xref{Symbolic Links}.
 | 
						|
 | 
						|
@item ENOTDIR
 | 
						|
A file that is referenced as a directory component in the file name
 | 
						|
exists, but it isn't a directory.
 | 
						|
 | 
						|
@item ELOOP
 | 
						|
Too many symbolic links were resolved while trying to look up the file
 | 
						|
name.  The system has an arbitrary limit on the number of symbolic links
 | 
						|
that may be resolved in looking up a single file name, as a primitive
 | 
						|
way to detect loops.  @xref{Symbolic Links}.
 | 
						|
@end table
 | 
						|
 | 
						|
 | 
						|
@node File Name Portability,  , File Name Errors, File Names
 | 
						|
@subsection Portability of File Names
 | 
						|
 | 
						|
The rules for the syntax of file names discussed in @ref{File Names},
 | 
						|
are the rules normally used by @gnusystems{} and by other POSIX
 | 
						|
systems.  However, other operating systems may use other conventions.
 | 
						|
 | 
						|
There are two reasons why it can be important for you to be aware of
 | 
						|
file name portability issues:
 | 
						|
 | 
						|
@itemize @bullet
 | 
						|
@item
 | 
						|
If your program makes assumptions about file name syntax, or contains
 | 
						|
embedded literal file name strings, it is more difficult to get it to
 | 
						|
run under other operating systems that use different syntax conventions.
 | 
						|
 | 
						|
@item
 | 
						|
Even if you are not concerned about running your program on machines
 | 
						|
that run other operating systems, it may still be possible to access
 | 
						|
files that use different naming conventions.  For example, you may be
 | 
						|
able to access file systems on another computer running a different
 | 
						|
operating system over a network, or read and write disks in formats used
 | 
						|
by other operating systems.
 | 
						|
@end itemize
 | 
						|
 | 
						|
The @w{ISO C} standard says very little about file name syntax, only that
 | 
						|
file names are strings.  In addition to varying restrictions on the
 | 
						|
length of file names and what characters can validly appear in a file
 | 
						|
name, different operating systems use different conventions and syntax
 | 
						|
for concepts such as structured directories and file types or
 | 
						|
extensions.  Some concepts such as file versions might be supported in
 | 
						|
some operating systems and not by others.
 | 
						|
 | 
						|
The POSIX.1 standard allows implementations to put additional
 | 
						|
restrictions on file name syntax, concerning what characters are
 | 
						|
permitted in file names and on the length of file name and file name
 | 
						|
component strings.  However, on @gnusystems{}, any character except
 | 
						|
the null character is permitted in a file name string, and
 | 
						|
on @gnuhurdsystems{} there are no limits on the length of file name
 | 
						|
strings.
 |