List、Set、Map三种集合
1、List集合
List集合包括 ArrayList,LinkedList、Vector
1)ArrayList
List<String> list=new ArrayList<String>();
list.add("A");
list.add("B");
list.add("C");
list.add("A");
System.out.println(list.size());//答应集合的长度,这里是4
//遍历集合
for (String str : list) {
System.out.println(str);
}
2)LinkedList
LinkedList<String> list=new LinkedList<String>();
list.add("A");
list.add("B");
list.add("C");
list.add("A");
list.addFirst("first");//增加到第一行
list.addLast("last");//增加到最后一行
list.removeFirst();//移除掉第一个
for (String str : list) {
System.out.println(str);
}
3)Vector
Vector v = new Vector();
for(int i = 0; i < 10; i++)
v.addElement("Hello World"+i);
System.out.println(v);
}
2、Set集合
Set集合包括HashSet、TreeSet
1)HashSet
HashSet<String> hashSet=new HashSet<String>();
hashSet.add("A");
hashSet.add("C");
hashSet.add("B");
hashSet.add(null);
//HashSet可以加空值
for (String str : hashSet) {
System.out.println(str);
}
2)TreeSet
TreeSet<String> treeSet=new TreeSet<String>(); treeSet.add("A"); treeSet.add("C"); treeSet.add("B"); treeSet.add(null);
for (String str : treeSet) { System.out.println(str); }
3、Map集合Map集合包括 HashMap、HashTable、TreeMap、迭代Map
1)HashMap
2)HashTableMap<String, Object> map=new HashMap<String, Object>(); map.put("A", "AAAA"); map.put("2", "2222"); map.put("3", "3333"); map.put("王", "大小王"); //三种拿值的方法 //遍历 //01.获取所有的键,再根据键获取值 Set<String> strings=map.keySet(); for (String string : strings) { System.out.println(string+":"+map.get(string)); } //02.获取所有的值 Collection<Object> collection=map.values(); for (Object object : collection) { System.out.println(object); } //03.获取键和值(一个一个) Set<Entry<String, Object>> entries=map.entrySet(); for (Entry<String, Object> entry : entries) { System.out.println(entry.getKey() + " " + entry.getValue()); }
Hashtable arrays = new Hashtable(); arrays.put("Array1", "1"); arrays.put("Array2", "2"); arrays.put("Array3", "3"); //以下是遍历Hashtable: Enumeration keys = arrays.keys(); while( keys.hasMoreElements() ) { Object key = keys.nextElement(); Object value = arrays.get(key); System.out.println(value); }
3)TreeMap4)迭代MapTreeMap map = new TreeMap(); map.put("a","a"); map.put("b", "b"); map.put("c","c"); Collection col = map.values(); Iterator it = col.iterator(); while(it.hasNext()) { System.out.println(it.next()); }
HashMap的三种拿值方法就是迭代Map的用法
1.map.keySet();
2.map.values();
3.entry.getValue();
区别
List
<1>ArrayList
数组结构,查询快,增删改慢
<2>LinkedList(特有方法addFirst)
链表结构,查询慢,增删改快
<3>Vector
增删改查慢
Set
<1>HashSet可以加空值
<2>TreeSet不可以加空值
Map
<1>HashMap 可以加空值(无序)
<2>HashTable 不能加空值(无序)
<3>TreeMap 可以加空值(有序)
三种集合分享完毕,欢迎大家指点一二