Is it possible to make anonymous inner classes in Java static?
No, you can't, and no, the compiler can't figure it out. This is why FindBugs always suggests changing anonymous inner classes to named static
nested classes if they don't use their implicit this
reference.
Edit: Tom Hawtin - tackline says that if the anonymous class is created in a static context (e.g. in the main
method), the anonymous class is in fact static
. But the JLS disagrees:
An anonymous class is never
abstract
(§8.1.1.1). An anonymous class is always an inner class (§8.1.3); it is neverstatic
(§8.1.1, §8.5.1). An anonymous class is always implicitlyfinal
(§8.1.1.2).
Roedy Green's Java Glossary says that the fact that anonymous classes are allowed in a static context is implementation-dependent:
If you want to baffle those maintaining your code, wags have discovered
javac.exe
will permit anonymous classes insidestatic
init code andstatic
methods, even though the language spec says than anonymous classes are neverstatic
. These anonymous classes, of course, have no access to the instance fields of the object. I don’t recommend doing this. The feature could be pulled at any time.
Edit 2: The JLS actually covers static contexts more explicitly in §15.9.2:
Let C be the class being instantiated, and let i be the instance being created. If C is an inner class then i may have an immediately enclosing instance. The immediately enclosing instance of i (§8.1.3) is determined as follows.
- If C is an anonymous class, then:
- If the class instance creation expression occurs in a static context (§8.1.3), then i has no immediately enclosing instance.
- Otherwise, the immediately enclosing instance of i is
this
.
So an anonymous class in a static context is roughly equivalent to a static
nested class in that it does not keep a reference to the enclosing class, even though it's technically not a static
class.
Kind of. An anonymous inner class created in a static method will obviously be effectively static because there is no source for an outer this.
There are some technical differences between inner classes in static contexts and static nested classes. If you're interested, read the JLS 3rd Ed.
I think there's a bit of confusion in the nomenclature here, which admittedly is too silly and confusing.
Whatever you call them, these patterns (and a few variations with different visibility) are all possible, normal, legal Java:
public class MyClass {
class MyClassInside {
}
}
public class MyClass {
public static class MyClassInside {
}
}
public class MyClass {
public void method() {
JComponent jc = new JComponent() {
...
}
}
}
public class MyClass {
public static void myStaticMethod() {
JComponent jc = new JComponent() {
...
}
}
}
They are catered for in the language spec (if you're really bothered, see section 15.9.5.1 for the one inside the static method).
But this quote is just plain wrong:
javac.exe will permit anonymous classes inside static init code and static methods, even though the language spec says than anonymous classes are never static
I think the quoted author is confusing the static keyword with static context. (Admittedly, the JLS is also a bit confusing in this respect.)
Honestly, all of the patterns above are fine (whatever you call them "nested", "inner", "anonymous" whatever...). Really, nobody is going to suddenly remove this functionality in the next release of Java. Honestly!
Inner classes can't be static - a static nested class is not an inner class. The Java tutorial talks about it here.