In case any C syntax like languages we specify the main() method should return anything int, float, void also. But in java can we do so? If not then why only void is used for main() method. Does it mean any java program doen't return anything to OS?
-
You can return an int with System.exit().
Returning anything other than an integer doesn't make much sense, as the OS expects an integer. In case nothing is returned the default is 0, which means OK. Other values typically are used to signal errors or special conditions.
-
Link to interesting discussion on velocityreviews on the same topic:
http://www.velocityreviews.com/forums/t135045-why-does-main-in-java-returns-void-.html
Highlight:
Incidentally, this is considered bad style in C and C++ just because it's the wrong signature for main, not for any universal reason independent of programming languages. It's one of those things that is not really supposed to work, but might on your implementation.
In Java, the reason main returns void is threads. C and C++ were both designed as languages before multithreading was a widely known technique, and both had threads grafted onto them at a later date. Java was designed from the beginning to be a multithreaded environment, and frankly, it would be unusual to write any non-trivial Java application that doesn't use more than one thread. So the idea that a program moves linearly from the beginning to the end of main is a bit outdated.
written by
www.designacourse.com
The Easiest Way to Train Anyone... Anywhere.
Chris Smith - Lead Software Developer/Technical Trainer MindIQ Corporation
-
The
main()
method must indeed have avoid
return type. From the Java Language Specification on "Execution - Virtual Machine Start-Up" (§12.1.4):The method
main
must be declaredpublic
,static
, andvoid
. It must accept a single argument that is an array of strings.It goes on to describe when a program exits in "Execution - Program Exit" (§12.8):
A program terminates all its activity and exits when one of two things happens:
- All the threads that are not daemon threads terminate.
- Some thread
invokes the
exit
method of classRuntime
or classSystem
and the exit operation is not forbidden by the security manager.
In other words, the program may exit before or after the
main
method finishes; a return value frommain
would therefore be meaningless. If you want the program to return a status code, call one of the following methods (note that all three methods never return normally):System.exit(int status)
- Equivalent toRuntime.getRuntime().exit(status)
Runtime.exit(int status)
- Terminates the currently running JVM by initiating its shutdown sequence (run all registered shutdown hooks, and uninvoked finalizers, if necessary). Once this is done the JVM halts.Runtime.halt(int status)
- Forcibly terminates the currently running JVM.
Of the three,
System.exit()
is the conventional and most convenient way to terminate the JVM. -
Reason for
main
method having void as return type is that oncemain
finishes, it doesn't necessariliy mean that entire program finished. Ifmain
spawns new threads, then these threads can keep program running. Return type of main doesn't make much sense at this point.For example, this is very common in Swing applications, where
main
method typically starts GUI on Swing thread, and thenmain
finishes... but program is still running.Max : @Peter: Peter, could you clarify for myself (currently exploring java multithreading)... Is it deamon threads ONLY that are NOT permitted to outlive main() ?Peter Štibraný : @Max: no, main() method has no control over JVM. When JVM starts, it will run main() method, but when main() finishes, it doesn't mean that JVM terminaes. JVM continues to execute all threads until 1) Runtime.exit() is called OR 2) all normal (not daemon) threads have died. Daemon threads do not count for this second condition. In other words ... if main() method spawns some normal threads, JVM will **not** terminate when main() finishes. If main() doesn't spawn any threads, JVM will terminate. If main() spawns only daemon threads, JVM will also terminate when main() finishes.Max : @Peter: Pete, thanks for clarif.
0 comments:
Post a Comment