Java集合框架的知识总结(1)
所有集合类都位于java.util包下。集合中只能保存对象(保存对象的引用变量)。
Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,这两个接口又包含了一些接口或实现类。
总的架构如下,非常重要,包含继承关系,实现的分类,
Collection接口:
Set接口:
HashSet具体类
LinkedHashSet具体类
TreeSet具体类
List接口: ArrayList具体类
LinkedList具体类
向量类Vector具体类
Stack具体类
Map接口: HashMap类
LinkedHashMap类
TreeMap类
Set和List接口是Collection接口派生的两个子接口。
Map实现类用于保存具有映射关系的数据(key-value)。
Collection接口,它是处理对象集合的根接口,提供了一些公用方法,size,Iterator,add,remove什么的
Set、List和Map可以看做集合的三大类。
List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根据元素的索引来访问。
Set集合是无序集合,集合中的元素不可以重复,访问集合中的元素只能根据元素本身来访问(也是不能集合里元素不允许重复的原因)。
Map集合中保存Key-value对形式的元素,访问时只能根据每项元素的key来访问其value。
Vector 和ArrayList的异同
实现原理,功能相同,可以互用
主要区别:
Vector线程安全,ArrayList重速度轻安全,线程非安全。长度需增长时,vector默认增长一倍。ArrayList增长50%
Hashtable和HashMap的异同
实现原理,功能相同,可以互用
主要区别:
Hashtable继承Dictionary类,HashMap实现Map接口,Hashtable线程安全,HashMap线程非安全
Hashtable不允许null值,HashMap允许null值
public class TestK {
public static void main(String [] args){
Collection col =new ArrayList();
//增加元素
col.add(1);
col.add(2);
System.out.println(col);
//集合长度 System.out.println(col.size());
//可重复,有序(不唯一,有序)
List<String> list =new ArrayList<String>();
list.add("aaa");
list.add("bbb");
list.add("aaa");
//向指定位置,插入元素
list.add(1,"ccc");
String val= list.get(0);
//删除指定位置值(返回删除掉的值)
c.remove(6);
//是否包含指定元素
boolean flag=list.contains("bbb");
System.out.println(list);
System.out.println(val);
System.out.println(flag);
}
}
ArrayList和Linkedlist的区别:
A:都实现了List
B:ArrayList是可变长数组方式实现,查询效率高,LinkedList是链接方式实现,增加和删除效率高;
Map常用方法(键值对方式存储数据)
Map<Key,Value> maps =new HashMap<Key,Value>();
public class TestMap {
public static void main(String [] args){
//key-->value
//名字-->企鹅
Map<String,Penguin> maps=new HashMap<String,Penguin>();
//增加
Penguin p=new Penguin();
p.setName("欧欧");
p.setSex("男");
maps.put("欧欧",p);
//取值
//maps.get(key)
Penguin p1=maps.get("欧欧");
p1.print();
// System.out.println(maps);
//大小
System.out.println(maps.size());
//是否包含key
System.out.println(maps.containsKey("欧欧"));
//删除
maps.remove("欧欧");
}
}
注意:key是唯一的如果重复那么后面的会覆盖前面的,value是可以重复的