In a recent question, someone asked about static methods and one of the answers stated that you generally call them with something like:
MyClassName.myStaticMethod();
The comments on that also stated that you could also call it via an object with:
MyClassName myVar;
myVar.myStaticMethod();
but that it was considered bad form.
Now it seems to me that doing this can actually make my life easier so I don’t have to worry about what’s static or not (a).
Is there some problem with calling static functions via an object? Obviously you wouldn’t want to create a brand new object just to call it:
Integer xyzzy;
int plugh = xyzzy.parseInt ("42", 10);
But, if you already have an object of the desired type, is there a problem in using it?
(a) Obviously, I can’t call a non-static method with:
MyClassName.myNonStaticMethod();
but that’s not the issue I’m asking about here.
The bad form comment comes from the Coding Conventions for Java
See http://www.oracle.com/technetwork/java/codeconventions-137265.html#587
The reason for it, if you think about it, is that the method, being static, does not belong to any particular object. Because it belongs to the class, why would you want to elevate a particular object to such a special status that it appears to own a method?
In your particular example, you can use an existing integer through which to call
parseInt(that is, it is legal in Java) but that puts the reader’s focus on that particular integer object. It can be confusing to readers, and therefore the guidance is to avoid this style.Regarding this making life easier for you the programmer, turn it around and ask what makes life easier on the reader? There are two kinds of methods: instance and static. When you see a the expression
C.mand you knowCis a class, you knowmmust be a static method. When you seex.m(wherexis an instance) you can’t tell, but it looks like an instance method and so most everyone reserves this syntax for instance methods only.