集合使用通配符之后数据的读取和写入要求
关于我们使用通配符福之后数据的读取和写入的要求我们也是通过举例加分析的方式来学习
//这个时候我们声明了一个List<?>类型的引用,没有指向任何一个实例对象
List<?> list1 = null;
//这里创建了一个ArrayList<String>类型的对象
List<String> list2 = new ArrayList<>();
list2.add("AA");
list2.add("BB");
list2.add("CC");
//这个时候我们就是List<?>类型的引用指向了一个ArrayList<String>类型的对象
list1 = list2;
写入:
这个时候对于list1,我们就不可以向其内部添加数据,除了添加null以外:
- 就连String类型的数据都不可以添加,这个时候我们的List<?>是可以配对所有的类型的
读取:
允许读取数据,只不过读取的数据的类型会自动转为Object类型
- 这个时候我们可以对读取到的数据使用向下转型转为我们的实际类型
eg:
package 泛型.通配符;
import java.util.ArrayList;
import java.util.List;
public class Demo {
public static void main(String[] args) {
List<?> list1 = null;
List<String> list2 = new ArrayList<>();
list2.add("abc");
list2.add("abc");
list2.add("abc");
list1 = list2;
String s = (String)list1.get(0);
System.out.println(s);
}
}
- 在这个上面如果我们不使用向下转型,这个时候我们直接得到Object类型的返回子,这个时候如果我们直接输出这个Object类型的返回值,我们得到的会是什么?
- 这个时候我们会得到一个字符串"abc",这个时候为什么我们得到的不是一个 全类名#地址编码的十六进制?
- 因为这个时候虽然编译期间是一个Object类型的参数,但是这个参数在我们输出的时候就会变成String类型,因为这个时候这Object类型的引用指向了一个String类型的对象,这个时候编译看左边,虽然我们输出看起来输出的是一个Object类型的数据,但是这个时候运行是看的右边,这个时候输出的时候就会将这个Object类型的引用看为它的实际类型,也就是编译看右边,也就是运行期间当做String类型来处理,所以这个时候输出这个Object类型的引用其实调用的是String类型的toString()方法,而不是调用Object类型的toString()方法
- 这个时候我们会得到一个字符串"abc",这个时候为什么我们得到的不是一个 全类名#地址编码的十六进制?