Java高級之HashMap中的entrySet()方法使用
基本使用
entrySet()方法得到HashMap中各個鍵值對映射關(guān)系的集合。
然后Map.Entry中包含了getKey()和getValue()方法獲取鍵和值。
示例:
public class Demo { public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map.put("abc", "123"); map.put("efg", "456"); // 使用增強型for遍歷循環(huán)Map集合 Set<Map.Entry<String, String>> entrySet = map.entrySet(); for (Map.Entry<String, String> entry : entrySet) { System.out.println(entry.getKey() + "->" + entry.getValue()); } } } /** * 打印結(jié)果: * abc->123 * efg->456 */
原理剖析
HashMap的entrySet()方法返回Set<Map.Entry<String, String>>,那么為什么entrySet()方法可以得到鍵值對映射集合呢?
public Set<Map.Entry<K, V>> entrySet() { Set<Map.Entry<K, V>> es; return (es = entrySet) == null ? (entrySet = new EntrySet()) : es; }
其實entrySet()方法的原理和keySet()方法、values()方法的原理是一致的。
entrySet()方法的源碼注釋如下:
/** * 該方法返回值就是這個map中各個鍵值對映射關(guān)系的集合 * 1.Map中采用Entry內(nèi)部類來表示一個映射項,映射項包含Key和Value * 2.Map.Entry里面包含getKey()和getValue()方法 * * @return 返回map中各個鍵值對映射關(guān)系的集合 */ public Set<Map.Entry<K, V>> entrySet() { Set<Map.Entry<K, V>> es; return (es = entrySet) == null ? (entrySet = new EntrySet()) : es; /* 等價于(代碼復(fù)雜化) Set<Map.Entry<K, V>> es = entrySet; if (es == null) { entrySet = new EntrySet(); return entrySet; } else { return es; } */ }
那么看看編譯后生成的字節(jié)碼文件Demo.class
public class Demo { public Demo() { } public static void main(String[] args) { Map<String, String> map = new HashMap(); map.put("abc", "123"); map.put("efg", "456"); Set<Entry<String, String>> entrySet = map.entrySet(); Iterator var3 = entrySet.iterator(); while(var3.hasNext()) { Entry<String, String> entry = (Entry)var3.next(); System.out.println((String)entry.getKey() + "->" + (String)entry.getValue()); } } }
能夠獲取到元素是通過迭代器Iterator遍歷得來的,所以entrySet()方法能有鍵值對的映射集合,是因為iterator()方法。
那么iterator()方法是哪里的呢?
在entrySet()方法中使用new實例化了一個EntrySet類
查看EntrySet類源碼,里面有個iterator()方法,字節(jié)碼文件中調(diào)用的就是該iterator()方法
在該方法的return語句中又實例化了EntryIterator類作為返回值,是一個迭代器,查看EntryIterator類的源碼,只有一個next()方法
該方法被調(diào)用返回的類型就是Map.Entry<K, V>,而得到的結(jié)果是nextNode()方法的返回值。
nextNode()方法的作用就是返回下一個結(jié)點。
而Entry是Map的內(nèi)部接口,該Entry接口有幾個方法可以設(shè)置或得到鍵值。
所以能夠通過entry.getKey()和entry.getValue()方法獲取到鍵和值。
并且Node<K, V>是Map.Entry<K, V>的實現(xiàn)類。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot注入yml配置文件 list報錯的解決方案
這篇文章主要介紹了springboot注入yml配置文件 list報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08spring cloud oauth2 feign 遇到的坑及解決
這篇文章主要介紹了spring cloud oauth2 feign 遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03Java中InputSteam怎么轉(zhuǎn)String
面了一位實習(xí)生,叫他給我說一下怎么把InputStream轉(zhuǎn)換為String,這種常規(guī)的操作,他竟然都沒有用過我準(zhǔn)備結(jié)合工作經(jīng)驗,整理匯集出了InputStream 到String 轉(zhuǎn)換的十八般武藝,助大家闖蕩 Java 江湖一臂之力,需要的朋友可以參考下2021-06-06SpringBoot JPA懶加載失效的解決方案(親測有效)
這篇文章主要介紹了SpringBoot JPA懶加載失效的解決方案(親測有效),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08JAVA中堆、棧,靜態(tài)方法和非靜態(tài)方法的速度問題
這篇文章主要介紹了JAVA中堆、棧,靜態(tài)方法和非靜態(tài)方法的速度問題,堆和棧得速度性能分析多角度給大家分析,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08