Forums Register Login

Instantiating the class containing the main method

+Pie Number of slices to send: Send
I don't know the reason why, but I feel uncomfortable instantiating the class containing the main method, as in this example:

It feels more natural to keep the main method in one class, and create a second class for the purpose of instantiation.
For example:

Either method works. Is there a reason to prefer one over the other?
Should I just learn to get over it?
+Pie Number of slices to send: Send
I prefer the second method because it gets you used to handling multiple classes.
If you create a command‑line application, you can remove the class with the main method and use its public interface behind a GUI. Then you put a new main method in, which calls the application via the GUI.
+Pie Number of slices to send: Send
Campbell's point is valid and the second approach is more technically robust but I suspect most people just put the main method in their application class. So I would say use the second version if you feel more comfortable with it but just remember most code you look at will probably be written along the lines of the first version.
+Pie Number of slices to send: Send
I suspect most books use the first method because the code is more concise. In real life, I use the second method. More often than not, the command line apps that we build tend to use some sort of IoC (either through our custom configuration driven factories, or Spring) to initialize the app, so it makes more sense to keep the main method that calls the IoC to initialize the app from the app itself.
Squanch that. And squanch this tiny ad:
a bit of art, as a gift, the permaculture playing cards
https://gardener-gift.com


reply
reply
This thread has been viewed 1460 times.
Similar Threads
Why it is illegal to use abstract and static modifiers together in method declaration ?
Inferring type in call to generic method: how does it work?
static block and empty block inside any class.
Inner Class Doubts
Anonymous inner class
More...

All times above are in ranch (not your local) time.
The current ranch time is
Apr 16, 2024 02:58:55.