成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

Java Map.entry案例詳解

瀏覽:3日期: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
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产一区二区按摩在线观看| 韩国女主播成人在线| 日本成人在线一区| 日韩视频在线一区二区三区| 中文字幕第一区综合| 99re成人在线| 欧美一区二区三区在线观看| 免费精品视频在线| 色噜噜久久综合| 天堂va蜜桃一区二区三区漫画版| 一区二区三区欧美成人| 日韩一区欧美小说| 极品中文字幕一区| 自拍偷拍欧美激情| 国内精品久久久久久久影视麻豆 | 亚洲五码中文字幕| 国产精品日本| 亚洲午夜日本在线观看| 亚洲精品专区| 依依成人精品视频| 99精品国产福利在线观看免费| 亚洲乱码国产乱码精品精可以看| 亚洲成色精品| 亚洲婷婷在线视频| 亚洲国产一区二区三区高清| 亚洲欧洲在线观看av| 亚洲图片在线| 亚洲激情校园春色| 欧美亚洲三级| 蜜臀va亚洲va欧美va天堂| 久久久久中文| 久久99在线观看| 欧美一区二区三区免费观看视频| 成人h动漫精品一区二区| 精品av综合导航| 欧美在线视屏| 亚洲欧美综合另类在线卡通| 99精品热视频只有精品10| 亚洲精品免费电影| 久久精品日产第一区二区| 日本麻豆一区二区三区视频| 91.com视频| 波多野结衣精品在线| 久久久久久久综合色一本| 欧美成人综合一区| 亚洲婷婷综合色高清在线| 亚洲欧美电影在线观看| 奇米色777欧美一区二区| 欧美精品三级在线观看| 成人一级片在线观看| 国产三级精品视频| 一区二区黄色| 免费人成在线不卡| 欧美大片在线观看一区二区| 欧美日韩国产成人精品| 亚洲精品视频一区| 在线这里只有精品| 成人视屏免费看| 国产精品传媒在线| 色偷偷88欧美精品久久久| 韩国精品在线观看| 精品国产电影一区二区| 在线精品在线| 久久精品国产77777蜜臀| 精品国产一区二区三区不卡| 欧美日韩一区二区视频在线| 亚洲成av人**亚洲成av**| 欧美日韩国产成人在线免费| av电影在线观看不卡| 亚洲欧洲一区二区在线播放| 老司机精品视频网站| 福利91精品一区二区三区| 中文字幕五月欧美| 在线观看一区二区精品视频| av在线播放不卡| 国产精品国产自产拍高清av| 久久精品五月婷婷| 国产成人免费视频网站高清观看视频| 国产欧美精品日韩区二区麻豆天美| 一区二区激情| 国产老妇另类xxxxx| 国产精品久久久久影院亚瑟| 日本韩国欧美三级| 成人av在线播放网址| 亚洲欧美日韩综合aⅴ视频| 欧美午夜电影一区| 91视频xxxx| 天堂午夜影视日韩欧美一区二区| 精品日韩成人av| 免费在线日韩av| 成人h动漫精品一区二区| 亚洲狠狠爱一区二区三区| 日韩精品资源二区在线| 香蕉久久夜色精品国产| 成人性生交大片免费看中文网站| 亚洲欧美日韩久久| 91精品国产综合久久福利| 99精品免费网| av在线一区二区| 日本欧美大码aⅴ在线播放| 日本一区免费视频| 欧美性极品少妇| 伊人影院久久| 国产成人在线视频网站| 亚洲一线二线三线久久久| 欧美一级高清片在线观看| av成人天堂| 国产精品亚洲视频| 亚洲制服丝袜av| 久久婷婷色综合| 色狠狠av一区二区三区| 欧美日韩1080p| 韩国女主播成人在线观看| 亚洲精品日产精品乱码不卡| 精品久久五月天| 色94色欧美sute亚洲13| 国内精品久久国产| 成人免费av网站| 日本不卡视频一二三区| 一区在线播放视频| 日韩三级高清在线| 久久永久免费| 欧美日韩hd| 国产99精品视频| 日韩专区一卡二卡| **性色生活片久久毛片| 日韩欧美一区二区视频| 色呦呦日韩精品| 精品成人国产| 不卡影院免费观看| 日本不卡不码高清免费观看| 自拍偷自拍亚洲精品播放| 欧美xingq一区二区| 91极品美女在线| 日韩午夜精品| 91免费版在线| 国产电影一区在线| 久久国产欧美日韩精品| 亚洲大片免费看| 中文字幕佐山爱一区二区免费| 久久久久九九视频| 日韩一区和二区| 精品视频一区三区九区| 国产精品嫩草99av在线| 欧美视频在线观看| 99久久精品久久久久久清纯| 国产一区二区精品久久99| 日韩高清在线观看| 亚洲一区二区精品久久av| 亚洲欧洲日本在线| 日本一区二区三区四区| 精品久久久三级丝袜| 欧美三级日本三级少妇99| 美女精品在线| 一本久道久久综合狠狠爱| 午夜激情一区| 99在线精品观看| 成人中文字幕合集| 国产福利一区二区三区| 久久99精品国产麻豆婷婷| 日本不卡高清视频| 视频精品一区二区| 亚州成人在线电影| 亚洲精品视频在线观看免费| 成人欧美一区二区三区在线播放| 国产亚洲精品福利| 久久综合视频网| 精品日产卡一卡二卡麻豆| 日韩欧美国产不卡| 欧美精品18+| 欧美日韩激情一区二区三区| 欧美中文字幕一区二区三区| 久久久久久亚洲精品不卡4k岛国| 国产午夜久久| 亚洲美洲欧洲综合国产一区| 在线欧美视频| 亚洲国产精品久久久久婷婷老年| 国产精品草草| 欧美日韩hd| 狠狠综合久久av一区二区老牛| 色综合欧美在线| 欧美 日韩 国产在线| 欧美~级网站不卡| 欧美另类一区| 欧美日韩久久| 欧美婷婷久久| 在线看无码的免费网站| 亚洲一二区在线| 亚洲黑丝一区二区| 在线亚洲观看| 久久亚洲美女| 欧美亚洲高清一区二区三区不卡| 欧美日韩免费电影| 91精品国产福利在线观看| 日韩欧美中文字幕一区| 精品国产一区二区三区久久影院| 国产亚洲欧美在线| 国产精品国产三级国产三级人妇| 亚洲女子a中天字幕| 亚洲老司机在线|