This question already has an answer here:
Please notice the code below doesn't compile, failing on the method result assignment: String s = a.method("abc");
.
The compilation error: incompatible types: java.lang.Object cannot be converted to java.lang.String
But, when changing A a
to A<?> a
or to A<Object> a
, the compilation passes.
* Please notice that the type <T>
in the method is different than the type <O>
in the class.
Any idea what the compilation error? Also, why the generic definition in variable a
solves the compilation issue?
class A<O>
{
O something;
<T> T method(T t)
{
return t;
}
static void testJavaStrangeGenericDefinitionBehavior()
{
A a = null;
String s = a.method("abc");
}
}
It's because Java's
type erasure
meaning for backward compatibility all generic type declarations exist only in source code and after compilation they are converted toObject
references and proper casts behind the scenes so theJVM
in this case is confused that you meantO
orT
.should be:
Although, you could substitute any class for
String
since, as you say, theT
andO
generics are different types.Once you remove the generic parameter, you lose all the generics in your method call, which essentially becomes equivalent to calling: