Map接口的概述
- Map接口的概述
1肌似、將鍵映射到值的對象费就;
2、一個(gè)映射不能包含重復(fù)的鍵川队;
3力细、每個(gè)鍵最多只能映射到一個(gè)值; - Map接口和Collection接口的不同
1固额、Map是雙列的眠蚂,Collection是單列的;
2斗躏、Map是鍵唯一逝慧,Collection的子體系Set是唯一的;
3、Collection集合的數(shù)據(jù)結(jié)構(gòu)是針對元素有效笛臣;
Map集合的功能概述
1云稚、添加功能:
V put(K key,V value)
:添加元素沈堡;
//創(chuàng)建集合對象
Map<Integer,String> map=new HashMap<Integer, String>();
//添加元素
map.put(1,"hello");
map.put(2,"world");
System.out.println(map);
成功存儲兩個(gè)鍵值對静陈;但是再看下面這個(gè):
//添加元素
map.put(1,"hello");
map.put(1,"world");
System.out.println(map);
說明了,當(dāng)鍵值相同時(shí)踱蛀,前面的值將會被修改窿给,所以這個(gè)方法也可以修改指定位置的元素;
2率拒、刪除功能:
void clear
:移除所有的鍵值元素崩泡;V remove(object key)
:根據(jù)鍵刪除值對元素,并把值返回猬膨;3角撞、判斷功能:
boolean containsKey(Object key)
:判斷是否包含指定的鍵;boolean containsKey(Object value)
:判斷是否包含指定的值勃痴;boolean isEmpty
:判斷集合是否為空谒所;4、獲取功能:
V get(object key)
:根據(jù)鍵獲取值沛申;
//根據(jù)鍵獲取值
System.out.println("根據(jù)鍵獲取值是:"+map.get(1));
set<K> keySet()
:獲取集合中所有值得集合劣领;
//獲取集合中所有鍵的集合
Set<Integer> set=map.keySet();
for(Integer key:set){
System.out.println(key);
}
Collection<V> values()
:獲取集合中所有值的集合;
//獲取集合中所有值的集合
Collection<String> conn=map.values();
for(String values:conn){
System.out.println(values);
}
Map集合的遍歷:
package com.manman_01;
/*
* Map集合的遍歷:
* 思路:
* 把所有的鍵集中起來铁材;
* 遍歷鍵的集合尖淘,獲取得到每一個(gè)鍵
* 讓鍵去匹配值;
* 獲取所有的鍵
* 遍歷鍵的集合著觉,獲取得到每一個(gè)鍵
* 根據(jù)鍵去找值
*/
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class MapDemo1 {
public static void main(String[] args) {
//創(chuàng)建集合對象
Map<Integer,String> map=new HashMap<Integer, String>();
//添加元素
map.put(1,"hello");
map.put(2,"world");
map.put(3, "java");
//遍歷
Set<Integer> set=map.keySet();
//遍歷鍵的集合村生,獲取每一個(gè)鍵
for(Integer key:set){
String value=map.get(key);
System.out.println(key+"-->"+value);
}
}
}
5、
int size()
:返回集合中的鍵值對的個(gè)數(shù)饼丘;
map.put(1,"hello");
map.put(2,"world");
//System.out.println(map);
//獲取長度
System.out.println("長度是:"+map.size());
Map的子類HashMap
- HashMap:是基于哈希表的Map接口實(shí)現(xiàn)的趁桃;哈希表的作用是用來保證鍵的唯一性的。
package com.manman_02;
import java.util.HashMap;
import java.util.Set;
public class HashMapDemo {
public static void main(String[] args) {
//創(chuàng)建集合對象
HashMap<Integer, String> hm=new HashMap<Integer, String>();
//創(chuàng)建元素并添加元素
hm.put(1, "hello");
hm.put(2, "world");
hm.put(3, "java");
hm.put(3, "android");
//遍歷
Set<Integer> set=hm.keySet();
for(Integer key:set){
String value=hm.get(key);
System.out.println(key+"-->"+value);
}
}
}
- 練習(xí)
1肄鸽、遍歷自定義集合
package com.manman_02;
import java.util.HashMap;
import java.util.Set;
public class HashMapDemo2 {
public static void main(String[] args) {
//創(chuàng)建集合對象
HashMap<String, Student> hm=new HashMap<String, Student>();
//創(chuàng)建學(xué)生對象
Student student1=new Student("張三",20);
Student student2=new Student("李四",21);
Student student3=new Student("王五",22);
Student student4=new Student("劉柳",23);
//添加元素
hm.put("123",student1);
hm.put("124",student2);
hm.put("125",student3);
hm.put("126",student4);
//遍歷
Set<String> set=hm.keySet();
for(String key:set){
Student student=hm.get(key);
System.out.println(student.getName()+"-->"+student.getAge());
}
}
}
2卫病、
package com.manman_02;
import java.util.HashMap;
import java.util.Set;
/*
* HashMap<Student,String>
* 要求是:
* 如果兩個(gè)對象的成員變量值都相同,則為同一個(gè)對象
*/
public class HashMapDemo3 {
public static void main(String[] args) {
//創(chuàng)建集合對象
HashMap<Student, String> hm=new HashMap<Student, String>();
//創(chuàng)建學(xué)生對象
Student student1=new Student("張三",20);
Student student2=new Student("李四",21);
Student student3=new Student("王五",22);
Student student4=new Student("劉柳",23);
//添加元素
hm.put(student1,"第一");
hm.put(student2,"第二");
hm.put(student3,"第三");
hm.put(student4,"第四");
//遍歷
Set<Student> set=hm.keySet();
for(Student key:set){
String value=hm.get(key);
System.out.println(key.getAge()+"-->"+key.getName()+"-->"+value);
}
}
}
LinkedHashMap類的概述
- Map接口的哈希表和鏈接列表實(shí)現(xiàn)典徘,具有可預(yù)知的迭代順序蟀苛。
package com.manman_02;
import java.util.LinkedHashMap;
import java.util.Set;
public class LinkedHashMapDemo {
public static void main(String[] args) {
//創(chuàng)建集合對象
LinkedHashMap<String, String> hm=new LinkedHashMap<String, String>();
//創(chuàng)建并添加元素
hm.put("1", "張三");
hm.put("2", "李四");
hm.put("3", "王五");
hm.put("3", "麗麗");
//遍歷
Set<String> set=hm.keySet();
for(String key:set){
String value=hm.get(key);
System.out.println(key+"-->"+value);
}
}
}
TreeMap類的概述
- 基于紅黑樹的Map接口的實(shí)現(xiàn)
package com.manman_02;
import java.util.Set;
import java.util.TreeMap;
public class TreeMapDemo {
public static void main(String[] args) {
//創(chuàng)建集合對象
TreeMap<String, String> hm=new TreeMap<String, String>();
//創(chuàng)建并添加元素
hm.put("1", "張三");
hm.put("2", "李四");
hm.put("4", "王五");
hm.put("4", "麗麗");
//遍歷
Set<String> set=hm.keySet();
for(String key:set){
String value=hm.get(key);
System.out.println(key+"-->"+value);
}
}
}
- 練習(xí)
1、
package com.manman_02;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Set;
/*
* 要求是:假設(shè)HashMap集合的元素是ArrayList烂斋。有三個(gè)屹逛。
* 每一個(gè)ArrayList集合的值是字符串
*/
public class HashMapDemo5 {
public static void main(String[] args) {
//創(chuàng)建集合對象
HashMap<String, ArrayList<String>> hm=new HashMap<String , ArrayList<String>>();
//添加元素
//添加元素集合
ArrayList<String> arrayList1=new ArrayList<String>();
arrayList1.add("盧布");
ArrayList<String> arrayList2=new ArrayList<String>();
arrayList2.add("張良");
ArrayList<String> arrayList3=new ArrayList<String>();
arrayList3.add("鐘馗");
hm.put("第一", arrayList1);
hm.put("第二", arrayList2);
hm.put("第三", arrayList3);
//遍歷
Set<String> set=hm.keySet();
for(String key:set){
ArrayList<String> arrayList=hm.get(key);
for(String s:arrayList){
System.out.println(key+s);
}
}
}
}
2础废、
package com.manman_02;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Set;
/*
* ArrayList集合嵌套HashMap集合并遍歷
* 假設(shè)ArrayList集合的元素是HashMap。有三個(gè)罕模。
* 每個(gè)HashMap集合的建和值都是字符串
*/
public class HashMapDemo6 {
public static void main(String[] args) {
//創(chuàng)建集合對象
ArrayList<HashMap<String, String>> arrayhash=new ArrayList<HashMap<String,String>>();
//添加元素
//創(chuàng)建HashMap评腺,并添加元素
HashMap<String, String> hm1=new HashMap<String,String>();
hm1.put("文章", "馬伊琍");
HashMap<String, String> hm2=new HashMap<String,String>();
hm2.put("鄧超", "孫儷");
HashMap<String, String> hm3=new HashMap<String,String>();
hm3.put("黃磊", "孫莉");
arrayhash.add(hm1);
arrayhash.add(hm2);
arrayhash.add(hm3);
//遍歷
for(HashMap<String, String> hashMap:arrayhash){
Set<String> set=hashMap.keySet();
for(String key:set){
String value=hashMap.get(key);
System.out.println(key+"-->"+value);
}
}
}
}