1.集合概述
面向对象语言对事物的描述都是以对象的形式。但是要对多个对象操作就涉及要对对象进行存储。而java提供的Array存储又具有一些弊端(后续介绍),所以java集合就应运而生了。可以把多个对象的引用放入到一个容器中。那么存储多个对象可以有以下两种方式
一.数组存储
Student[] =student =new Student[20];
Student[0]=new Student();
以上可看出数组存储对象的弊端是长度不可变,一旦初始化长度指定为20 以后都是这个固定长度 还是真实存储个数不可知的弊端,你无法获知数组内真正存了多少元素
二.集合存储
ArrayList arrayList= new ArrayList();
arrayList.add("AA");
arrayList.add("BB");
arrayList.size();
以ArrayList为例 可以同size方法调用即可知道存放了多少元素
2.框架结构
以上为集合框架的结构图 主要分为两类Collection 和Map
一. Collection接口
- Set:元素无序、不可重复的集合
- List:元素有序,可重复的集合
Collection collection= new ArrayList();
collection.add("AA");//给集合添加子元素
collection.size();//返回集合元素个数
Collection col= Arrays.asList(1,2,3);
collection.addAll(col);//添加指定集合的所有元素
collection.contains("AA");//判断是否包含某个元素 (当添加自定义对象 自定义对象需要重写equals方法)
collection.contains("AA");//判断是否包含某个元素
collection.containsAll(col); //判断指定集合的所有元素是否都在该集合中
collection.retainAll(col); //取两个集合的交集
collection.remove("AA");//删除一个元素
collection.removeAll(col);//删除指定集合中所有元素
collection.equals(col);//判断两个集合中元素是否相同
collection.hashCode();//计算哈希值
collection.toArray();//将集合转化为数组
collection.add("BB");
collection.add("CC");
Iterator iterator= collection.iterator();//返回一个iterator接口实现类的对象
System.out.println(collection);
while (iterator.hasNext()){
System.out.println(iterator.next());
}
二. Map接口: 具有映射关系"key:value"的集合
- Map中的key和value都可以是任何引用类型的数据
- Map的key 用Set来存放 故不能重复
- 常用String类作为Map的键
- key 与value存在单向一对一关系
- TreeMap
- HashMap
- HashTable
- LinkedHashMap
Map map =new HashMap();
map.put("a","AA");//新增
map.get("a");//获取
map.remove("a");//删除
至此集合的大致框架结构已经讲完了,后续将实现类ArrayList HashMap等进行分析,欲听后续如何,且听下回分解!