一、引入
同一泛型类,如果实例化时给定的实际类型不同,则这些实例的类型是不兼容的,不能相互赋值
泛型类实例之间的不兼容性会带来使用的不便,我们可以使用泛型通配符(?)声明泛型类的变量。
Cls1 c1 = new Cls1(10);
Cls1 c2 = new Cls1(10.12);
Cls1
c1 = c2; //不能使用
c3 = c1; //不能使用
二、通配符使用
应用场景:不知道返回来是一个什么类型,需要一个变量来接收返回
“?”代表任意一个类型
Cls1 c1 = new Cls1(10);
Cls1 c2 = new Cls1(10.12);
Cls1 c3 = new Cls1(new Dog());
Cls1<?> c4; //通配符
c4 = c3;
c4 = c2;
c4 = c1;
和限制泛型上下限相似,同样可以使用extends限定通配类型
Cls1 c1 = new Cls1(10);
Cls1 c2 = new Cls1(10.12);
Cls1 c3 = new Cls1(new Dog());
Cls1<? extends Animal> c4; //通配符
c4 = c3; //只有这条可以
//c4 = c2;
//c4 = c1;
还可以使用super将通配符匹配类型限定为某个类型的下限
Cls1 c1 = new Cls1(10);
Cls1 c2 = new Cls1(10.12);
Cls1 c3 = new Cls1(new Dog());
//Cls1<? extends Animal> c4; //通配符
Cls1<? super Dog> c4;
c4 = c3; //只有这条可以
//c4 = c2;
//c4 = c1;