# JAVA之旅(二十二)——Map概述,子類對象特點,共性方法,keySet,entrySet,Map小練習
* * *
> 繼續堅持下去吧,各位騷年們!
>
> 事實上,我們的數據結構,只剩下這個Map的知識點了,平時開發中,也是能看到他的,所以還是非常值得去學習的一個知識點的,我們直接開車了
## 一.Map概述

> 泛型 鍵值對,映射關系
>
> 基本特點
* 該集合存儲鍵值對,是一對一對往里存,而且要保證鍵的唯一性?
* 1.添加?
* put(key ,values)
* putAll()
* 2.刪除?
* clear()
* remove(object key)
* 3.判斷?
* containsValue(Object value)
* containsKey(Object key)
* isEmpty()
* 4.獲取?
* get(Object key)
* size()
* values()
* entrySet()
* keySet()
> 我們的學習步驟也是這樣來的,
## 二.子類對象特點
> Map有三個子類
* Hashtable?
* 底層是哈希表數據結構,不可以存入null值或者鍵,該集合是線程同步的

* HashMap?
* 底層是哈希表數據結構,允許使用null的鍵值對,線程是不同步的。效率高

* TreeMap?
* 底層是二叉樹數據結構,線程不同步,可以用于給map集合中的鍵進行排序
> Map和Set很像,其實Set底層就是使用了Map集合
## 三.共性方法
> 我們看一下他們的共同點
~~~
package com.lgl.hellojava;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
// 添加元素
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
System.out.println("原數據:"+map);
// 判斷是否存在002的key
System.out.println(map.containsKey("002"));
//刪除
System.out.println(map.remove("002"));
System.out.println("刪除后:"+map);
//獲取
System.out.println("獲取:"+map.get("001"));
//可以通過get方法的返回值來判斷一個鍵是否存在
map.put(null, "haha");
System.out.println("null:"+map);
//獲取map集合中所有的值
Collection<String> values = map.values();
System.out.println("map的值:"+values);
}
}
~~~
> 這里可以看到輸出的結果

> 但是這里要注意的是,添加元素,如果添加的時候,相同的鍵,那么后面的,會被后添加的覆蓋原有的鍵對應的值,并put方法會返回被覆蓋的值
## 四.keySet
> 想取出他的值,他并沒有迭代器,那我們的思路可以轉變一下拿到他的所有的鍵再去get不就可以拿到鍵值對了,我們來看一下
* keySet?
* 將map中所有的值存入到Set集合中,因為Set具備迭代器,所有可以迭代方法取出的所有的鍵,根據get方法,獲取每一個鍵對應的值
~~~
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
// 先獲取map集合中的所有鍵的Set集合
Set<String> keySet = map.keySet();
// 有了Set集合就可以獲取迭代器
Iterator<String> iterator = keySet.iterator();
while (iterator.hasNext()) {
String string = iterator.next();
// 有了鍵可以通過map集合的get方法獲取其對應的值
String value = map.get(string);
System.out.println("key:" + string + "values:" + value);
}
}
}
~~~
> 這種方法還是比較好理解的,對吧,但是這樣比較麻煩,我們來看另一種
## 五.entrySet
~~~
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
// 將map集合中的映射關系取出,存入到Set集合中
Set<Entry<String, String>> entrySet = map.entrySet();
Iterator<Entry<String, String>> iterator = entrySet.iterator();
while (iterator.hasNext()) {
Map.Entry<String, String> entry = iterator.next();
System.out.println(entry.getKey() + ":" + entry.getValue());
}
}
}
~~~
> 定義泛型雖然比較麻煩,但是取出來還是比較簡單的,原理是什么?其實我們可以寫一段偽代碼來說明的
~~~
package com.lgl.hello;
public class HashMap implements Map {
class Hahs implements Map.Entry {
@Override
public Object getKey() {
// TODO Auto-generated method stub
return null;
}
@Override
public Object getValue() {
// TODO Auto-generated method stub
return null;
}
}
}
interface Map {
public static interface Entry {
public abstract Object getKey();
public abstract Object getValue();
}
}
~~~
> 父子接口,直接訪問,內部規則
## 六.Map小練習
> 我們可以通過一個小練習來學習一下使用規則,而需求,我直接寫在注釋上
~~~
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 每個學生都有對應的歸屬地 學生Student,地址String 學生屬性:姓名和年齡
* 注意:姓名和年齡相同的視為同一個學生,保證學生的唯一性
*
* 1.描述學生 2.定義Map容器,將學生作為鍵,地址作為值存入 3.獲取Map容器中的元素
*/
HashMap<Student, String> hm = new HashMap<Student, String>();
hm.put(new Student("zhangsan", 15), "beijing");
hm.put(new Student("lisi", 16), "shanghai");
hm.put(new Student("wangwu", 17), "guangzhou");
hm.put(new Student("liliu", 10), "shenzhen");
// 第一種取出方式keySet
Set<Student> keySet = hm.keySet();
Iterator<Student> iterator = keySet.iterator();
while (iterator.hasNext()) {
Student student = iterator.next();
String addr = hm.get(student);
System.out.println(student + ":" + addr);
}
//第二種取出方式 entrySet
Set<Entry<Student, String>> entrySet = hm.entrySet();
Iterator<Entry<Student, String>> iterator2 = entrySet.iterator();
while (iterator2.hasNext()) {
Entry<Student, String> next = iterator2.next();
System.out.println(next.getKey()+":"+next.getValue());
}
}
}
/**
* 描述學生
*
* @author LGL
*
*/
class Student implements Comparable<Student> {
private String name;
private int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public int hashCode() {
// TODO Auto-generated method stub
return name.hashCode() + age * 34;
}
@Override
public boolean equals(Object obj) {
if (!(obj instanceof Student))
throw new RuntimeException("類型不匹配");
Student s = (Student) obj;
return this.name.equals(s.name) && this.age == s.age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public int compareTo(Student s) {
int num = new Integer(this.age).compareTo(new Integer(s.age));
if (num == 0)
return this.name.compareTo(s.name);
return num;
}
}
~~~
> OK,例子就是用兩種取出的方式罷了,相信你自己也一定能做好的,好的,我們本節課到這里也就結束了,下節再見
## 有興趣的話,加下群:555974449
版權聲明:本文為博主原創文章,博客地址:http://blog.csdn.net/qq_26787115,未經博主允許不得轉載。
- 0-發現
- AndroidInterview-Q-A
- Android能讓你少走彎路的干貨整理
- LearningNotes
- temp
- temp11
- 部分地址
- 0-待辦任務
- 待補充列表
- 0-未分類
- AndroidView事件分發與滑動沖突處理
- Spannable
- 事件分發機制詳解
- 1-Java
- 1-Java-01基礎
- 未歸檔
- 你應該知道的JDK知識
- 集合框架
- 1-Java-04合集
- Java之旅0
- Java之旅
- JAVA之旅01
- JAVA之旅02
- JAVA之旅03
- JAVA之旅04
- JAVA之旅05
- JAVA之旅06
- JAVA之旅07
- JAVA之旅08
- JAVA之旅09
- java之旅1
- JAVA之旅10
- JAVA之旅11
- JAVA之旅12
- JAVA之旅13
- JAVA之旅14
- JAVA之旅15
- JAVA之旅16
- JAVA之旅17
- JAVA之旅18
- JAVA之旅19
- java之旅2
- JAVA之旅20
- JAVA之旅21
- JAVA之旅22
- JAVA之旅23
- JAVA之旅24
- JAVA之旅25
- JAVA之旅26
- JAVA之旅27
- JAVA之旅28
- JAVA之旅29
- java之旅3
- JAVA之旅30
- JAVA之旅31
- JAVA之旅32
- JAVA之旅33
- JAVA之旅34
- JAVA之旅35
- 1-Java-05辨析
- HashMapArrayMap
- Java8新特性
- Java8接口默認方法
- 圖解HashMap(1)
- 圖解HashMap(2)
- 2-Android
- 2-Android-1-基礎
- View繪制流程
- 事件分發
- AndroidView的事件分發機制和滑動沖突解決
- 自定義View基礎
- 1-安卓自定義View基礎-坐標系
- 2-安卓自定義View基礎-角度弧度
- 3-安卓自定義View基礎-顏色
- 自定義View進階
- 1-安卓自定義View進階-分類和流程
- 10-安卓自定義View進階-Matrix詳解
- 11-安卓自定義View進階-MatrixCamera
- 12-安卓自定義View進階-事件分發機制原理
- 13-安卓自定義View進階-事件分發機制詳解
- 14-安卓自定義View進階-MotionEvent詳解
- 15-安卓自定義View進階-特殊形狀控件事件處理方案
- 16-安卓自定義View進階-多點觸控詳解
- 17-安卓自定義View進階-手勢檢測GestureDetector
- 2-安卓自定義View進階-繪制基本圖形
- 3-安卓自定義View進階-畫布操作
- 4-安卓自定義View進階-圖片文字
- 5-安卓自定義View進階-Path基本操作
- 6-安卓自定義View進階-貝塞爾曲線
- 7-安卓自定義View進階-Path完結篇偽
- 8-安卓自定義View進階-Path玩出花樣PathMeasure
- 9-安卓自定義View進階-Matrix原理
- 通用類介紹
- Application
- 2-Android-2-使用
- 2-Android-02控件
- ViewGroup
- ConstraintLayout
- CoordinatorLayout
- 2-Android-03三方使用
- Dagger2
- Dagger2圖文完全教程
- Dagger2最清晰的使用教程
- Dagger2讓你愛不釋手-終結篇
- Dagger2讓你愛不釋手-重點概念講解、融合篇
- dagger2讓你愛不釋手:基礎依賴注入框架篇
- 閱讀筆記
- Glide
- Google推薦的圖片加載庫Glide:最新版使用指南(含新特性)
- rxjava
- 這可能是最好的RxJava2.x入門教程完結版
- 這可能是最好的RxJava2.x入門教程(一)
- 這可能是最好的RxJava2.x入門教程(三)
- 這可能是最好的RxJava2.x入門教程(二)
- 這可能是最好的RxJava2.x入門教程(五)
- 這可能是最好的RxJava2.x入門教程(四)
- 2-Android-3-優化
- 優化概況
- 各種優化
- Android端秒開優化
- apk大小優化
- 內存分析
- 混淆
- 2-Android-4-工具
- adb命令
- 一鍵分析Android的BugReport
- 版本控制
- git
- git章節簡述
- 2-Android-5-源碼
- HandlerThread 源碼分析
- IntentService的使用和源碼分析
- 2-Android-9-辨析
- LRU算法
- 什么是Bitmap
- 常見圖片壓縮方式
- 3-Kotlin
- Kotlin使用筆記1-草稿
- Kotlin使用筆記2
- kotlin特性草稿
- Kotlin草稿-Delegation
- Kotlin草稿-Field
- Kotlin草稿-object
- 4-JavaScript
- 5-Python
- 6-Other
- Git
- Gradle
- Android中ProGuard配置和總結
- gradle使用筆記
- Nexus私服搭建
- 編譯提速最佳實踐
- 7-設計模式與架構
- 組件化
- 組件化探索(OKR)
- 1-參考列表
- 2-1-組件化概述
- 2-2-gradle配置
- 2-3-代碼編寫
- 2-4-常見問題
- 2-9-值得一讀
- 8-數據結構與算法
- 0臨時文件
- 漢諾塔
- 8-數據-1數據結構
- HashMap
- HashMap、Hashtable、HashSet 和 ConcurrentHashMap 的比較
- 遲到一年HashMap解讀
- 8-數據-2算法
- 1個就夠了
- Java常用排序算法(必須掌握的8大排序算法)
- 常用排序算法總結(性能+代碼)
- 必須知道的八大種排序算法(java實現)
- 9-職業
- 閱讀
- 書單
- 面試
- 面試-01-java
- Java面試題全集駱昊(上)
- Java面試題全集駱昊(下)
- Java面試題全集駱昊(中)
- 面試-02-android
- 40道Android面試題
- 面試-03-開源源碼
- Android圖片加載框架最全解析(二),從源碼的角度理解Glide的執行流程
- 面試-07-設計模式
- 面試-08-算法
- 面試-09-其他
- SUMMARY
- 版權說明
- temp111