Pregunta

Lets say we have these packages and classes:

package p1;

public class A1 {
    public static void a() {}
}

package p2;

public class A1 {
    public static void a() {}
}

package p3;

import static p1.A1.a;
import static p2.A1.a;

public class A1 {
    public static void test() {

    }
}

I am wondering, why the static import of methods is legal (won't result in compile time error) in package p3? We won't be able to use them further in the test() method as such usage will result in the compile time error.

Why it is not the same as with a normal import of classes. Lets say we would like to import classes A1 from packages p1 and p2 into p3:

package p3;
import p1.A1;
import p2.A1;

such import is illegal and will result in the compile time error.

¿Fue útil?

Solución

The ambiguity of the static imports of methods could be resolved at the point of the method invocation.

For example if you had a static import for two methods that look like this:

void frobnicate(int i);
// and
void frobnicate(boolean b);

Then you could import and use both, because the compiler could tell which one to use, based on the arguments you pass in (frobnicate(1) calls the first one, frobnicate(true) calls the second one).

With classes, that's not possible: Foobar a; alone is not sufficient to tell you which of the two Foobar classes you want.

Also note that a single static import can import multiple names. According to the relevant section of the JLS (emphasis mine):

A single-static-import declaration imports all accessible static members with a given simple name from a type.

For example if the two frobnicate methods above where located in the same class, a single static import could import them both.

Otros consejos

It is because you have named all of these classes the same thing. Every time you call this static method it is looking in the most local class which in this case is the A1 in p3 which does not contain the static method a(). Always remember a class name should be unique and never the same as another.

I'm guessing, not backed by language spec, that methods can be overloaded, but fields/types cannot; therefore java allows importing methods of same name from different classes.

However two methods of the same signature cannot exist in same class; they ought not to be allowed either by imports.

Even if the two methods have different signatures, it is still a bad idea. The meaning of a name is very important, it should have clarity. We can handle overloaded methods from 1 class, but "overloading" across class is a stretch.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top