I've been brushing off my java and I've some misunderstanding about local classes (that I ultimately never used), I well understand the concept of static but not in the case of local classes.
1. Why is a static method not allowed in a local classes ?
2. Why is a static local class not allowed in a method ?
- A static method not allowed in a local classes:
Here I don't get it. To me the local class is tied to the static method main. I just don't understand why this cannot be done. The method main is accessed through the Sequence class and then since sayGoodbye is static it should be accessed through its class. But no.
public class Sequence {
public static void main(String... args) {
class EnglishGoodbye {
public static void sayGoodbye() { // this cannot be done
System.out.println("Bye bye");
}
}
EnglishGoodbye.sayGoodbye();
}
}
- A static local class not allowed in a method :
This cannot be done: It's a bit ambiguous but I'd think a static here would have the same meaning as a non static since the static class is tied to a static method. I'm confused.
public class Sequence {
public static void main(String... args) {
static class EnglishGoodbye { //static local classes not allowed
public static void sayGoodbye() {
System.out.println("Bye bye");
}
}
EnglishGoodbye.sayGoodbye();
}
}
Edit: The first answer I got was a quote from oracle :
Local classes are non-static because they have access to instance members of the enclosing block. Consequently, they cannot contain most kinds of static declarations.
and my reply :
That doesn't really explain everything though. When you have an inner class you can't access non static fields but you can access static fields. Same should apply for a local class, and since there is no static variable then it's useless. But what about methods, like in my example.
Okay I made a schema to better explain how I view things. It might be totally erroneous though and I'm a bit ashamed to show it. In this schema and in the scenario where a static local class would be accessible I'd have a local class in the top memory block. Whenever the static method2 would be called it would simply reference to it.
There are two kinds of classes in Java: Top-Level and Nested.
There are two kinds of Nested classes: Static Nested and Inner.
There are also two special kinds of Inner classes: Local and Anonymous.
Local and Anonymous classes are by definition Inner classes, i.e. non-static.
See The Java™ Tutorials - Local Classes Are Similar To Inner Classes:
But, you already saw that, so let me quote JLS §14.3 Local Class Declarations:
Reasoning (my opinion)
What is the point of the first example?
Just make the method a
private static
of the main class:Oh, did you want to access variables and parameters from the method?
Problem with that is that a
static
method has no instance context, so which instance ofmessage
would that be?To specify instance, a
new EnglishGoodbye()
statement is needed, and the compiler will add hidden instance fields toEnglishGoodbye
to represent the value ofmessage
, which is also whymessage
has to be (effectively) final, since it is copying the value of the variable. Remember, unlike C, you cannot reference a variable by pointer.Same goes for the second example. What is the point?
Just make the class a
private static
of the main class:Same reasoning as above for first example, if you has intended to access method variables and parameters. The class needs an instance, to know which instance of the variables/parameters to access.
Not that it's directly related to answer, but I made this, so might as well keep it.
Here is the Java type system as a hierarchy (not to be confused with inheritance/subtypes):
boolean
,byte
,short
,int
,long
,char
,float
,double
null
type (§4.1)