1.HashMap和Hashtable区别?的源
2.hashtableçåºå±å®ç°åç
3.hashmapåºå±å®ç°åç
HashMap和Hashtable区别?
两者最主要的区别在于hashtable是线程安全,而hashmap则非线程安全。原理
hashtable的的源实现方法里面都添加了synchronized关键字来确保线程同步,因此相对而言hashmap性能会高一些,原理osek os 源码我们平时使用时若无特殊需求建议使用hashmap,的源在多线程环境下若使用hashmap需要使用collections.synchronizedmap()方法来获取一个线程安全的原理文件上传源码集合(collections.synchronizedmap()实现原理是collections定义了一个synchronizedmap的内部类,这个类实现了map接口,的源在调用方法时使用synchronized来保证线程同步,原理当然了实际上操作的还是我们传入的hashmap实例,简单的的源说就是collections.synchronizedmap方法帮我们在操作hashmap时自动添加了synchronized来实现线程同步,类似的原理其它collections.synchronizedxx方法也是类似原理。
hashmap可以使用null作为key,的源不过建议还是原理尽量避免这样使用。hashmap以null作为key时,的源tomcat源码分析总是原理存储在table数组的第一个节点上。而hashtable则不允许null作为key。的源
hashmap继承了abstractmap,电脑维修源码hashtable继承dictionary抽象类,两者均实现map接口。
hashmap的网站统计源码初始容量为,hashtable初始容量为,两者的填充因子默认都是0.。
hashmap扩容时是当前容量翻倍即:capacity*2,hashtable扩容时是容量翻倍+1即:capacity*2+1。
hashmap和hashtable的底层实现都是数组+链表结构实现。
hashtableçåºå±å®ç°åç
hashtableåºå±å®ç°åçå¦ä¸ï¼
1ãHashTableç±»ä¸ï¼ä¿åå®é æ°æ®çï¼ä¾ç¶æ¯Entry对象ãå ¶æ°æ®ç»æä¸HashMapæ¯ç¸åçã
2ãHashTable类继æ¿èªDictionaryç±»ï¼å®ç°äºä¸ä¸ªæ¥å£ï¼åå«æ¯Mapï¼Cloneableåjava.io.Serializableã
3ãHashTableä¸ç主è¦æ¹æ³ï¼å¦putï¼getï¼removeårehashçï¼ä¸HashMapä¸çåè½ç¸åã
hashtableç±»å®ç°ä¸ä¸ªåå¸è¡¨ï¼è¯¥åå¸è¡¨å°é®æ å°å°ç¸åºçå¼ãä»»ä½énull对象é½å¯ä»¥ç¨ä½é®æå¼ã为äºæåå°å¨åå¸è¡¨ä¸åå¨åè·å对象ï¼ç¨ä½é®çå¯¹è±¡å¿ é¡»å®ç°hashCodeæ¹æ³åequalsæ¹æ³ãHashtableçå®ä¾æ两个åæ°å½±åå ¶æ§è½ï¼åå§å®¹éåå è½½å åãHashtableçå®ä¾æ两个åæ°å½±åå ¶æ§è½ï¼åå§å®¹éåå è½½å åã容éæ¯åå¸è¡¨ä¸æ¡¶çæ°éï¼åå§å®¹éå°±æ¯åå¸è¡¨å建æ¶ç容éã注æï¼åå¸è¡¨çç¶æ为openï¼å¨åçâåå¸å²çªâçæ åµä¸ï¼å个桶ä¼åå¨å¤ä¸ªæ¡ç®ï¼è¿äºæ¡ç®å¿ é¡»æ顺åºæç´¢ãå è½½å åæ¯å¯¹åå¸è¡¨å¨å ¶å®¹éèªå¨å¢å ä¹åå¯ä»¥è¾¾å°å¤æ»¡çä¸ä¸ªå°ºåº¦ãåå§å®¹éåå è½½å åè¿ä¸¤ä¸ªåæ°åªæ¯å¯¹è¯¥å®ç°çæ示ãå ³äºä½æ¶ä»¥åæ¯å¦è°ç¨rehashæ¹æ³çå ·ä½ç»èåä¾èµäºè¯¥å®ç°ã
hashmapåºå±å®ç°åç
hashmapåºå±å®ç°åçæ¯SortedMapæ¥å£è½å¤æå®ä¿åçè®°å½æ ¹æ®é®æåºï¼é»è®¤æ¯æé®å¼çååºæåºï¼ä¹å¯ä»¥æå®æåºçæ¯è¾å¨ï¼å½ç¨IteratoréåTreeMapæ¶ï¼å¾å°çè®°å½æ¯æè¿åºçãå¦æ使ç¨æåºçæ å°ï¼å»ºè®®ä½¿ç¨TreeMapãå¨ä½¿ç¨TreeMapæ¶ï¼keyå¿ é¡»å®ç°Comparableæ¥å£æè å¨æé TreeMapä¼ å ¥èªå®ä¹çComparatorï¼å¦åä¼å¨è¿è¡æ¶æåºjava.lang.ClassCastExceptionç±»åçå¼å¸¸ã
Hashtableæ¯éçç±»ï¼å¾å¤æ å°ç常ç¨åè½ä¸HashMap类似ï¼ä¸åçæ¯å®æ¿èªDictionaryç±»ï¼å¹¶ä¸æ¯çº¿ç¨å®å ¨çï¼ä»»ä¸æ¶é´åªæä¸ä¸ªçº¿ç¨è½åHashtable
ä»ç»æå®ç°æ¥è®²ï¼HashMapæ¯ï¼æ°ç»+é¾è¡¨+红é»æ ï¼JDK1.8å¢å äºçº¢é»æ é¨åï¼å®ç°çã
æ©å±èµæ
ä»æºç å¯ç¥ï¼HashMapç±»ä¸æä¸ä¸ªé常éè¦çå段ï¼å°±æ¯ Node[] tableï¼å³åå¸æ¡¶æ°ç»ãNodeæ¯HashMapçä¸ä¸ªå é¨ç±»ï¼å®ç°äºMap.Entryæ¥å£ï¼æ¬è´¨æ¯å°±æ¯ä¸ä¸ªæ å°(é®å¼å¯¹)ï¼é¤äºKï¼Vï¼è¿å å«hashånextã
HashMapå°±æ¯ä½¿ç¨åå¸è¡¨æ¥åå¨çãåå¸è¡¨ä¸ºè§£å³å²çªï¼éç¨é¾å°åæ³æ¥è§£å³é®é¢ï¼é¾å°åæ³ï¼ç®åæ¥è¯´ï¼å°±æ¯æ°ç»å é¾è¡¨çç»åãå¨æ¯ä¸ªæ°ç»å ç´ ä¸é½ä¸ä¸ªé¾è¡¨ç»æï¼å½æ°æ®è¢«Hashåï¼å¾å°æ°ç»ä¸æ ï¼ææ°æ®æ¾å¨å¯¹åºä¸æ å ç´ çé¾è¡¨ä¸ã
å¦æåå¸æ¡¶æ°ç»å¾å¤§ï¼å³ä½¿è¾å·®çHashç®æ³ä¹ä¼æ¯è¾åæ£ï¼å¦æåå¸æ¡¶æ°ç»æ°ç»å¾å°ï¼å³ä½¿å¥½çHashç®æ³ä¹ä¼åºç°è¾å¤ç¢°æï¼æ以就éè¦å¨ç©ºé´ææ¬åæ¶é´ææ¬ä¹é´æè¡¡ï¼å ¶å®å°±æ¯å¨æ ¹æ®å®é æ åµç¡®å®åå¸æ¡¶æ°ç»ç大å°ï¼å¹¶å¨æ¤åºç¡ä¸è®¾è®¡å¥½çhashç®æ³åå°Hash碰æã