日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java Map.entry案例詳解

瀏覽:24日期:2023-12-05 09:25:35

   Map.entrySet() 這個方法返回的是一個Set<Map.Entry<K,V>>,Map.Entry 是Map中的一個接口,他的用途是表示一個映射項(里面有Key和Value),而Set<Map.Entry<K,V>>表示一個映射項的Set。Map.Entry里有相應的getKey和getValue方法,即JavaBean,讓我們能夠從一個項中取出Key和Value。

下面是遍歷Map的四種方法:

public static void main(String[] args) { Map<String, String> map = new HashMap<String, String>(); map.put('1', 'value1'); map.put('2', 'value2'); map.put('3', 'value3'); //第一種:普遍使用,二次取值 System.out.println('通過Map.keySet遍歷key和value:'); for (String key : map.keySet()) { System.out.println('key= '+ key + ' and value= ' + map.get(key)); } //第二種 System.out.println('通過Map.entrySet使用iterator遍歷key和value:'); Iterator<Map.Entry<String, String>> it = map.entrySet().iterator(); while (it.hasNext()) { Map.Entry<String, String> entry = it.next(); System.out.println('key= ' + entry.getKey() + ' and value= ' + entry.getValue()); } //第三種:推薦,尤其是容量大時 System.out.println('通過Map.entrySet遍歷key和value'); for (Map.Entry<String, String> entry : map.entrySet()) { System.out.println('key= ' + entry.getKey() + ' and value= ' + entry.getValue()); } //第四種 System.out.println('通過Map.values()遍歷所有的value,但不能遍歷key'); for (String v : map.values()) { System.out.println('value= ' + v); } }

下面是HashMap的源代碼:

首先HashMap的底層實現用的時候一個Entry數組

/** * The table, resized as necessary. Length MUST Always be a power of two. */ transient Entry[] table; //聲明了一個數組 ........ public HashMap() { this.loadFactor = DEFAULT_LOAD_FACTOR; threshold = (int)(DEFAULT_INITIAL_CAPACITY * DEFAULT_LOAD_FACTOR); table = new Entry[DEFAULT_INITIAL_CAPACITY];//初始化數組的大小為DEFAULT_INITIAL_CAPACITY(這里是16) init(); }

再來看一下Entry是在什么地方定義的,繼續上源碼,我們在HashMap的源碼的674行發現了它的定義,原來他是HashMap的一個內部類,并且實現了Map.Entry接口,以下有些地方是轉載

static class Entry<K,V> implements Map.Entry<K,V> { final K key; V value; Entry<K,V> next; final int hash;/** * Creates new entry. */ Entry(int h, K k, V v, Entry<K,V> n) { value = v; next = n; key = k; hash = h; }public final K getKey() { return key; }public final V getValue() { return value; }public final V setValue(V newValue) { V oldValue = value; value = newValue; return oldValue; }public final boolean equals(Object o) { if (!(o instanceof Map.Entry)) return false; Map.Entry e = (Map.Entry)o; Object k1 = getKey(); Object k2 = e.getKey(); if (k1 == k2 || (k1 != null && k1.equals(k2))) { Object v1 = getValue(); Object v2 = e.getValue(); if (v1 == v2 || (v1 != null && v1.equals(v2))) return true; } return false; }public final int hashCode() { return (key==null ? 0 : key.hashCode()) ^ (value==null ? 0 : value.hashCode()); }public final String toString() { return getKey() + '=' + getValue(); }/** * This method is invoked whenever the value in an entry is * overwritten by an invocation of put(k,v) for a key k that’s already * in the HashMap. */ void recordAccess(HashMap<K,V> m) { }/** * This method is invoked whenever the entry is * removed from the table. */ void recordRemoval(HashMap<K,V> m) { } }

既然這樣那我們再看一下Map.Entry這個接口是怎么定義的,原來他是Map的一個內部接口并且定義了一些方法

interface Entry<K,V> { /** * Returns the key corresponding to this entry. * * @return the key corresponding to this entry * @throws IllegalStateException implementations may, but are not * required to, throw this exception if the entry has been * removed from the backing map. */ K getKey();/** * Returns the value corresponding to this entry. If the mapping * has been removed from the backing map (by the iterator’s * <tt>remove</tt> operation), the results of this call are undefined. * * @return the value corresponding to this entry * @throws IllegalStateException implementations may, but are not * required to, throw this exception if the entry has been * removed from the backing map. */ V getValue();/** * Replaces the value corresponding to this entry with the specified * value (optional operation). (Writes through to the map.) The * behavior of this call is undefined if the mapping has already been * removed from the map (by the iterator’s <tt>remove</tt> operation). * * @param value new value to be stored in this entry * @return old value corresponding to the entry * @throws UnsupportedOperationException if the <tt>put</tt> operation * is not supported by the backing map * @throws ClassCastException if the class of the specified value * prevents it from being stored in the backing map * @throws NullPointerException if the backing map does not permit * null values, and the specified value is null * @throws IllegalArgumentException if some property of this value * prevents it from being stored in the backing map * @throws IllegalStateException implementations may, but are not * required to, throw this exception if the entry has been * removed from the backing map. */ V setValue(V value); /** * Compares the specified object with this entry for equality. * Returns <tt>true</tt> if the given object is also a map entry and * the two entries represent the same mapping. More formally, two * entries <tt>e1</tt> and <tt>e2</tt> represent the same mapping * if<pre> * (e1.getKey()==null ? * e2.getKey()==null : e1.getKey().equals(e2.getKey())) && * (e1.getValue()==null ? * e2.getValue()==null : e1.getValue().equals(e2.getValue())) * </pre> * This ensures that the <tt>equals</tt> method works properly across * different implementations of the <tt>Map.Entry</tt> interface. * * @param o object to be compared for equality with this map entry * @return <tt>true</tt> if the specified object is equal to this map * entry */ boolean equals(Object o); /** * Returns the hash code value for this map entry. The hash code * of a map entry <tt>e</tt> is defined to be: <pre> * (e.getKey()==null ? 0 : e.getKey().hashCode()) ^ * (e.getValue()==null ? 0 : e.getValue().hashCode()) * </pre> * This ensures that <tt>e1.equals(e2)</tt> implies that * <tt>e1.hashCode()==e2.hashCode()</tt> for any two Entries * <tt>e1</tt> and <tt>e2</tt>, as required by the general * contract of <tt>Object.hashCode</tt>. * * @return the hash code value for this map entry * @see Object#hashCode() * @see Object#equals(Object) * @see #equals(Object) */ int hashCode(); }

看到這里的時候大伙兒估計都明白得差不多了為什么HashMap為什么要選擇Entry數組來存放key-value對了吧,因為Entry實現的Map.Entry接口里面定義了getKey(),getValue(),setKey(),setValue()等方法相當于一個javaBean,對鍵值對進行了一個封裝便于后面的操作,從這里我們其實也可以聯想到不光是HashMap,譬如LinkedHashMap,TreeMap 等繼承自map的容器存儲key-value對都應該使用的是Entry只不過組織Entry的形式不一樣,HashMap用的是數組加鏈表的形式,LinkedHashMap用的是鏈表的形式,TreeMap應該使用的二叉樹的形式,不信的話上源碼

LinkedHashMap:

/** * The head of the doubly linked list. */ /定義了鏈頭 private transient Entry<K,V> header;

初始化鏈表的方法:

void init() { header = new Entry<K,V>(-1, null, null, null); header.before = header.after = header; }

TreeMap:

//定義根節點 private transient Entry<K,V> root = null;

再看他的put方法,是不是很面熟(二叉排序樹的插入操作)

public V put(K key, V value) { Entry<K,V> t = root; if (t == null) { // TBD: // 5045147: (coll) Adding null to an empty TreeSet should // throw NullPointerException // // compare(key, key); // type check root = new Entry<K,V>(key, value, null); size = 1; modCount++; return null; } int cmp; Entry<K,V> parent; // split comparator and comparable paths Comparator<? super K> cpr = comparator; if (cpr != null) { do { parent = t; cmp = cpr.compare(key, t.key); if (cmp < 0) t = t.left; else if (cmp > 0) t = t.right; else return t.setValue(value); } while (t != null); } else { if (key == null) throw new NullPointerException(); Comparable<? super K> k = (Comparable<? super K>) key; do { parent = t; cmp = k.compareTo(t.key); if (cmp < 0) t = t.left; else if (cmp > 0) t = t.right; else return t.setValue(value); } while (t != null); } Entry<K,V> e = new Entry<K,V>(key, value, parent); if (cmp < 0) parent.left = e; else parent.right = e; fixAfterInsertion(e); size++; modCount++; return null; }

ok,明白了各種Map的底層存儲key-value對的方式后,再來看看如何遍歷map吧,這里用HashMap來演示吧

Map提供了一些常用方法,如keySet()、entrySet()等方法,keySet()方法返回值是Map中key值的集合;entrySet()的返回值也是返回一個Set集合,此集合的類型為Map.Entry。

so,很容易寫出如下的遍歷代碼

1. Map map = new HashMap(); Irerator iterator = map.entrySet().iterator(); while(iterator.hasNext()) { Map.Entry entry = iterator.next(); Object key = entry.getKey(); // } 2.Map map = new HashMap(); Set keySet= map.keySet(); Irerator iterator = keySet.iterator; while(iterator.hasNext()) { Object key = iterator.next(); Object value = map.get(key); // } 另外,還有一種遍歷方法是,單純的遍歷value值,Map有一個values方法,返回的是value的Collection集合。通過遍歷collection也可以遍歷value,如[java] view plain copyMap map = new HashMap(); Collection c = map.values(); Iterator iterator = c.iterator(); while(iterator.hasNext()) { Object value = iterator.next();

到此這篇關于Java Map.entry案例詳解的文章就介紹到這了,更多相關Java Map.entry內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久高清免费| 欧美粗暴jizz性欧美20| 99亚洲精品| 久久久久国产| 日韩啪啪电影网| 在线手机中文字幕| 亚洲伦乱视频| 激情久久中文字幕| 99在线|亚洲一区二区| 中文日韩欧美| 激情婷婷综合| 国产一区成人| 免费的成人av| 一区二区不卡| 青青草91久久久久久久久| 青青青国产精品| 久久国产乱子精品免费女| 欧美精品国产白浆久久久久| 欧美aⅴ一区二区三区视频| 麻豆精品视频在线观看视频| 久久av在线| 91精品国产一区二区在线观看| 日韩av电影一区| 国产精品成人自拍| 国产黄大片在线观看| 国产一区二区三区四区五区| 日韩国产一区二区| 欧美一区二区性| 国产视频一区在线观看一区免费| 国产精品社区| 中文字幕日韩高清在线| 97久久中文字幕| 久久精品国产福利| 福利片在线一区二区| 欧美精品一区二区久久| 男女精品网站| 国产日韩欧美中文在线| 亚洲欧洲美洲av| 婷婷亚洲五月| 亚洲精品三级| 国产美女撒尿一区二区| 97精品国产一区二区三区| 国产国产精品| 欧美日韩一区二区国产| 日韩国产欧美一区二区| 麻豆精品91| 亚洲午夜天堂| 久久xxxx| 久久精品亚洲一区二区| 美女网站一区| 国产乱人伦丫前精品视频| 日韩黄色大片网站| 日韩精品一二三四| 久久只有精品| 国产精品婷婷| 国产私拍福利精品视频二区| 久久久一二三| 天堂av一区| 美女av在线免费看| 免费美女久久99| 国产成人精品亚洲线观看| 亚洲精品91| 国产精品hd| 夜夜嗨av一区二区三区网站四季av| 欧美日韩一区二区三区不卡视频 | 日韩成人免费| 蜜桃成人av| 久久精品国产免费| 午夜在线视频一区二区区别| 久久久国产精品网站| 伊人久久亚洲美女图片| 欧美极品一区二区三区| 国产精品社区| 在线看片国产福利你懂的| 日韩区欧美区| 久久久久99| 国产精品a久久久久| 亚洲女同一区| 亚洲国产欧美日本视频| 欧美影院视频| 国产精品毛片在线| 美女久久精品| 天海翼亚洲一区二区三区| 亚洲成人精品| 久久99国产精品视频| 伊人久久大香伊蕉在人线观看热v| 美女久久99| 亚洲天堂av资源在线观看| 99久久精品费精品国产| 国产精品igao视频网网址不卡日韩| 亚洲电影在线一区二区三区| 精品一二三区| 亚洲精品字幕| 久久精品不卡| 日本一区二区免费高清| 青青草伊人久久| 日韩精品1区| 国产另类在线| 亚洲精选久久| 好看的亚洲午夜视频在线| 国产va在线视频| 日本免费一区二区视频| 精品三级久久久| 日韩精品免费一区二区夜夜嗨| 欧美色图一区| 不卡福利视频| 国产精品15p| 日本在线观看不卡视频| 免费av一区| 亚洲va中文在线播放免费| 国产精品久久久久久久久久白浆| 噜噜噜久久亚洲精品国产品小说| 日韩成人亚洲| 国产在线不卡一区二区三区| 欧美日韩亚洲一区在线观看| 在线观看一区| 欧美精品黄色| 免费观看久久av| 日韩国产一区| 国产精品精品| 欧美xxxx中国| 国产精品v日韩精品v欧美精品网站| 日韩精品三级| 婷婷久久免费视频| 一区二区日韩免费看| 亚洲一级淫片| 另类国产ts人妖高潮视频| 性一交一乱一区二区洋洋av| 午夜在线精品偷拍| 亚洲婷婷丁香| 亚洲精品动态| 91欧美精品| 国产福利资源一区| 国产精品久久国产愉拍| 久久久久伊人| 成人在线超碰| 日本美女一区| 99精品视频在线观看免费播放| 久久久水蜜桃av免费网站| 欧美日韩精品一区二区视频| 欧美sss在线视频| 日韩欧美国产精品综合嫩v| 日韩精品电影| 红桃视频国产精品| 一二三区精品| 国产精品嫩草影院在线看| 精品一区视频| 91精品蜜臀一区二区三区在线| 最新国产拍偷乱拍精品| 中文字幕日韩高清在线| 国产精品嫩草影院在线看| 精品国产精品久久一区免费式 | 国产精品1区在线| 大香伊人久久精品一区二区| 日韩av二区在线播放| 四虎精品一区二区免费| 日本成人在线网站| 国产精品啊啊啊| 国产欧美日韩一区二区三区在线| 欧美亚洲tv| 精品午夜久久| 免费成人网www| 日韩精品一二区| 国产精品xxxav免费视频| 91九色综合| 久久久久久色 | 国产91久久精品一区二区| 亚洲欧美日韩精品一区二区| 亚洲欧美日韩一区在线观看| 日韩**一区毛片| 国产伦精品一区二区三区视频 | 精品精品国产三级a∨在线| 天堂资源在线亚洲| 亚洲成人一区| 日韩国产精品久久久久久亚洲| 亚洲精品看片| 成人污污视频| 粉嫩av一区二区三区四区五区| 婷婷丁香综合| 国产精品麻豆成人av电影艾秋| 91一区二区三区四区| 蜜桃av一区二区三区电影| 91嫩草精品| 国产99久久| 日本不卡中文字幕| 久久精品二区亚洲w码 | 欧美另类专区| 午夜久久av| 国产精品视频一区二区三区综合| 一区二区亚洲精品| 日本视频一区二区| 国产91一区| 日韩av在线播放中文字幕| 青青久久av| 亚洲精品视频一二三区| 999久久久精品国产| 成人在线超碰| 亚洲日本免费电影| 在线一区视频观看| 日本一区二区三区视频在线看|