EXIT_FAILURE vs exit(1)?

CExit

C Problem Overview


What's the difference? Which is preferred, or when should I use each one respectively?

C Solutions


Solution 1 - C

exit(1) (usually) indicates unsuccessful termination. However, its usage is non-portable. For example, on OpenVMS, exit(1) actually indicates success.

Only EXIT_FAILURE is the standard value for returning unsuccessful termination, but 1 is used for the same in many implementations.


So to summarize:
If you want to write perfectly portable code use,

EXIT_FAILURE for failure case. While,
You can use either exit(0) or EXIT_SUCCESS for success case.

Note that, EXIT_SUCCESS or 0 are both same.


Reference:

C99 Standard: 7.20.4.3 The exit function
Para 5

> Finally, control is returned to the host environment. If the value of status is zero or EXIT_SUCCESS, an implementation-defined form of the status successful termination is returned. If the value of status is EXIT_FAILURE, an implementation-defined form of the status unsuccessful termination is returned. Otherwise the status returned is implementation-defined.

Solution 2 - C

For truly portable code, EXIT_FAILURE is preferred. The C standard only defines meaning for three values: EXIT_FAILURE, 0, and EXIT_SUCCESS (with 0 and EXIT_SUCCESS essentially synonymous).

From a practical viewpoint, most typical systems accept other values as well. If memory serves, Linux will let you return any 8-bit value, and Windows 16-bit values. Unless you honestly might care about porting to an IBM mainframe, VMS, etc., chances are you don't care about most of the systems that won't support at least 8-bit return values.

Solution 3 - C

Use EXIT_FAILURE. It is a constant that is used throughout the OS. Its value could be something else than 1 and also it is more descriptive in the code.

Solution 4 - C

There are conventions for what sorts of status values certain programs should return. The most common convention is simply 0 for success and 1 for failure. Programs that perform comparison use a different convention: they use status 1 to indicate a mismatch, and status 2 to indicate an inability to compare. Your program should follow an existing convention if an existing convention makes sense for it.

> Some non-POSIX systems use different conventions for exit status > values. For greater portability, you can use the macros EXIT_SUCCESS > and EXIT_FAILURE for the conventional status value for success and > failure, respectively. They are declared in the file stdlib.h.

Solution 5 - C

Not only VMS has its own rules also AmigaDOS defines a return code below 5 as okay.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questiontemporary_user_nameView Question on Stackoverflow
Solution 1 - CAlok SaveView Answer on Stackoverflow
Solution 2 - CJerry CoffinView Answer on Stackoverflow
Solution 3 - CEd HealView Answer on Stackoverflow
Solution 4 - CRavindra BagaleView Answer on Stackoverflow
Solution 5 - CPolluksView Answer on Stackoverflow