Error Handling
This week, I will discuss the C errno facility and its interfaces.
Each system call returns a status code. A zero value indicates success
whereas small negative numbers represent error codes. The
implementation automatically stores a system call's return value in a
global variable called errno, and each invocation of the system call
overwrites the previous errno value (note that in multithreaded
environments, each thread has a distinct errno). errno and its
associated functions are declared in the standard header file
The perror() function has the following prototype:
void perror(const char * msg);
perror() takes an error description string as an argument and prints it
to stderr (typically, the console). In addition to the user-supplied
string, perror() adds a colon and a verbal description of the current
errno value. The common approach passes the program's filename as an
argument. For example:
if (open("db_file.dat", O_RDONLY)<0)
perror ("database.c"); /*pass current filename*/
The output may look as follows:
database.c: No such file or directory
Remember, do not append a newline character to the argument; perror()
will add one after the error description.
Translating an error code to its verbal description may be useful if,
for example, you wish to log the error messages or format them before
printing. Use the function strerror() for this purpose. strerror() has
the following prototype:
char * strerror(int errcode);
The function takes an error code and returns a statically allocated
string describing that code. Remember that subsequent calls to strerror
() overwrite the description string. Unless you intend to use it
immediately, you should copy it to a local string. Using strerror(),
the following example translates the current errno code to a string
that is printed to the user's screen:
printf("error: %s", strerror(errno));
In addition to these functions,
pointers to error messages called sys_errlist. The elements of
sys_errlist are const strings, so you cannot modify them. The following
example retrieves the error description associated with the current
errno value by using sys_errlist and errno as the index:
printf("error: %s", sys_errlist[errno]);
sys_errlist use is deprecated and non-portable; however, it may exist
in legacy code. The strerror() function remains the preferred
alternative for retrieving the error description associated with an
errno code.
» posted by ITworld staff
ITworld
Sign up for ITworld's Daily newsletter
Follow ITworld on Twitter @IT_world
jfruh
Apple syncing patent can't come soon enough
pasmith
New Twitter features borrow from 3rd party clients
Esther Schindler
Open Source Changes the Software Acquisition Process
mikelgan
How to set up continuous podcast play on the new iTunes
David Strom
Five important Windows 7 mobility features
sjvn
Guard your Wi-Fi for your own sake
Sandra Henry-Stocker
Grepping on Whole Words
Sidekick: The Good News & the Bad News
Either way you look at it Microsoft Data Center management did not follow standards or best practices in this failure. In which case it makes me wonder more about the outsourcing of corporate data much less personal data.
- mburton325
Join the conversation here
Quick, practical advice for IT pros. Made fresh daily.
Want to cash in on your IT savvy? Send your tip to tips@itworld.com. If we post it, we'll send you a $25 Amazon e-gift card.












