Java集合类知识点总结
集合:只能存储对象,对象类型可以不一样,长度可变。
常用的接口和类:
1、List接口(有序、可重复):ArrayList类、LinkedList、Vector类
2、Set接口(无序、不能重复):HashSet类、TreeSet类
3、Map接口(键值对、键唯一、值不唯一):HashMap类、Hashtable类、TreeMap类
集合类的循环遍历
1、普通for循环:如for(inti=0;i 2、foreach(增强型for循环):如for(Objecti:arr){…} 3、Iterator(迭代器):如Iteratorit=arr.iterator();while(it.hasNext()){Objecto=it.next();…} 注意:无法在遍历的过程中对数组或者集合进行修改,而for循环可以在遍历的过程中对源数组或者集合进行修改 ArrayList、LinkedList和Vector的区别 ArrayList:效率高,多用于查询 LinkedList:多用于插入和删除 Vector:线程安全,多用于查询 代码: HashSet和TreeSet的区别 HashSet:HashSet是哈希表实现的,HashSet中的数据是无序的,可以放入null,但只能放入一个null TreeSet:TreeSet是二差树实现的,Treeset中的数据是自动排好序的,不允许放入null值 代码: 注意:Set接口没有get方法,所以不能使用普通for循环来遍历 HashMap、Hashtable和TreeMap的区别 HashMap:HashMap允许存在一个为null的key,多个为null的value Hashtable:hashtable的key和value都不允许为null TreeMap:能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器,当用Iterator遍历TreeMap时,得到的记录是排过序的 代码: 关于线程安全的类有:Vecto、HashTabl、StringBuffe 非线程安全:ArrayList、LinkedList、HashMap、HashSet、TreeMap、TreeSet、StringBulider 注意:ConcurrentHashMap可代替HashMap用于线程安全,且效率比Hashtable高 java自身的机制并不能完全保证线程安全。需要自己手动编码控制。 声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
importjava.util.ArrayList;
importjava.util.Iterator;
importjava.util.LinkedList;
importjava.util.List;
importjava.util.Vector;
publicclassListTest{
publicstaticvoidmain(String[]args){
ListarrayList=newArrayList();
ListlinkedList=newLinkedList();
Listvector=newVector();
arrayList.add("1");//字符类型
arrayList.add("1");//重复元素
arrayList.add("2");
arrayList.add(1);//数字类型
linkedList.add("1");
linkedList.add("1");
linkedList.add("2");
linkedList.add(1);
vector.add("1");
vector.add("1");
vector.add("2");
vector.add(1);
for(Objectobj:arrayList){//foreach循环
System.out.println(obj);
}
for(inti=0;i
publicclassSetTest{
publicstaticvoidmain(String[]args){
SethashSet=newHashSet();
SettreeSet=newTreeSet();
hashSet.add("1");//字符类型
hashSet.add("1");//重复元素
hashSet.add("2");
hashSet.add(1);//数字类型
treeSet.add("1");
treeSet.add("1");
treeSet.add("2");
// treeSet.add(1);//报错,treeSet不能添加不同的数据类型
for(Objecti:hashSet){//foreach循环
System.out.println(i);
}
Iteratorit=treeSet.iterator();//迭代器
while(it.hasNext()){
Objectj=it.next();
System.out.println(j);
}
}
}
importjava.util.HashMap;
importjava.util.Hashtable;
importjava.util.Iterator;
importjava.util.Map;
importjava.util.Set;
importjava.util.TreeMap;
publicclassMapTest{
publicstaticvoidmain(String[]args){
MaphashMap=newHashMap();
Maphashtable=newHashtable();
MaptreeMap=newTreeMap();
hashMap.put(1,"1");//字符类型值
hashMap.put(2,"1");//同值不同键
hashMap.put(3,"2");
hashMap.put(4,1);//数字类型值
hashMap.put("5",1);//字符类型键
hashtable.put(1,"1");
hashtable.put(2,"1");
hashtable.put(3,"2");
hashtable.put(4,1);
hashtable.put("5",1);
treeMap.put(1,"1");
treeMap.put(2,"1");
treeMap.put(5,"2");
treeMap.put(4,1);
// treeMap.put("5",1);//报错,TreeMap不能添加不同类型的键
//遍历hashMap键
for(Objectkey:hashMap.keySet()){
System.out.println(key);
}
//遍历hashtable值
for(Objectvalue:hashtable.values()){
System.out.println(value);
}
//遍历hashMap键值对
Setset=hashMap.keySet();
for(Iteratoriter=set.iterator();iter.hasNext();){
Objectkey=iter.next();
Objectvalue=hashMap.get(key);
System.out.println(key+"\t"+value);
}
//迭代遍历hashtable键值对,倒序!
Iteratortable=hashtable.entrySet().iterator();
while(table.hasNext()){
Map.Entryentry=(Map.Entry)table.next();
Objectkey=entry.getKey();//取键
Objectvalue=entry.getValue();//取值
System.out.println(key+"\t"+value);
}
//迭代遍历treeMap键值对
Iteratortmp=treeMap.entrySet().iterator();
while(tmp.hasNext()){
Map.Entryentry=(Map.Entry)tmp.next();
Objectkey=entry.getKey();//取键
Objectvalue=entry.getValue();//取值
System.out.println(key+"\t"+value);
}
}
}