Why has setting the entry point's return type to void
in C++ always been discouraged, and was later removed by the standard and is prohibited by modern compilers? Why is it considered bad practice?
Now, as I understand C# and Java both allow the entry point's return type to be void
i.e
static void main(String[] args) /* Java */
static void Main(string[] args) /* C# */
And C# and Java programmers do not consider it bad practice, they use it often in fact.
Other languages which are (only intended to be, I doubt C++ will be succeeded in this decade, at least) possible successors of C++ like the D Programming Language or Vala also allow a void main()
. So as you can see, I doubt the C++ community removed it from the standard because it was too obscure or unpopular.
So my question is, Why did the C++ Community Remove void main()
? What was wrong with it?
C++ has never permitted
void main()
, though some compilers might permit it either as an extension or just because they don't diagnose it.Similarly C has never permitted
void main()
other than as an extension; the same 1989 standard that introduced thevoid
keyword defined the two standard definitions formain
:int main(void)
andint main(int argc, char *argv[])
.Other languages permit it because, well, they're other languages.
There is no particular advantage in being able to write
void main()
rather thanint main()
. You don't even need to explicitly return a value; falling off the end ofmain
is equivalent toreturn 0;
(in C++, and in C starting with C99).The C++ standards committee likely chose to require
int main()
because of the large body of existing code that expected to use areturn
statement to return a specific exit code to the runtime system. It would be unreasonable to expect all existing code to change to useexit()
instead, soint main()
was made a requirement in the standard.A language such as Java, when it was designed, did not have any body of existing code that it needed to remain compatible with. Therefore, the designers could choose
void main()
and require the use ofSystem.exit()
for non-zero exit codes.So, the thing that would be "wrong" with choosing
void main()
for the C++ standard would be that it would break existing code that expected to usereturn
and an exit code value frommain()
.You generally want to know the exit status of your program. That's the reason why you have the
int main()
-- you return your exit status.It's wrong because this is not what the C++ Standard specifies as a legal
main
. Nobody cares about what the other languages specify. For C++ programs, only the C++ Standard is relevant, and it saysint
.