Java是一種可以撰寫跨平臺應(yīng)用軟件的面向?qū)ο蟮某绦蛟O(shè)計(jì)語言低剔。Java 技術(shù)具有卓越的通用性、高效性肮塞、平臺移植性和安全性襟齿,廣泛應(yīng)用于PC、數(shù)據(jù)中心枕赵、游戲控制臺猜欺、科學(xué)超級計(jì)算機(jī)、移動(dòng)電話和互聯(lián)網(wǎng)拷窜,同時(shí)擁有全球最大的開發(fā)者專業(yè)社群开皿。
給你學(xué)習(xí)路線:html-css-js-jq-javase-數(shù)據(jù)庫-jsp-servlet-Struts2-hibernate-mybatis-spring4-springmvc-ssh-ssm
小編推薦一個(gè)學(xué)Java的學(xué)習(xí)裙【 六五零涧黄,五五四,六零七 】赋荆,無論你是大牛還是小白笋妥,是想轉(zhuǎn)行還是想入行都可以來了解一起進(jìn)步一起學(xué)習(xí)!裙內(nèi)有開發(fā)工具窄潭,很多干貨和技術(shù)資料分享春宣!
HashMap和HashTable的區(qū)別
HashMap線程不安全,HashTable是線程安全的嫉你。HashMap內(nèi)部實(shí)現(xiàn)沒有任何線程同步相關(guān)的代碼月帝,所以相對而言性能要好一點(diǎn)。如果在多線程中使用HashMap需要自己管理線程同步幽污。HashTable大部分對外接口都使用synchronized包裹嚷辅,所以是線程安全的,但是性能會(huì)相對差一些距误。
二者的基類不一樣潦蝇。HashMap派生于AbstractMap,HashTable派生于Dictionary深寥。它們都實(shí)現(xiàn)Map, Cloneable, Serializable這些接口。AbstractMap中提供的基礎(chǔ)方法更多贤牛,并且實(shí)現(xiàn)了多個(gè)通用的方法惋鹅,而在Dictionary中只有少量的接口,并且都是abstract類型殉簸。
key和value的取值范圍不同闰集。HashMap的key和value都可以為null,但是HashTablekey和value都不能為null般卑。對于HashMap如果get返回null武鲁,并不能表明HashMap不存在這個(gè)key,如果需要判斷HashMap中是否包含某個(gè)key蝠检,就需要使用containsKey這個(gè)方法來判斷沐鼠。
算法不一樣。HashMap的initialCapacity為16叹谁,而HashTable的initialCapacity為11饲梭。HashMap中初始容量必須是2的冪,如果初始化傳入的initialCapacity不是2的冪,將會(huì)自動(dòng)調(diào)整為大于出入的initialCapacity最小的2的冪焰檩。HashMap使用自己的計(jì)算hash的方法(會(huì)依賴key的hashCode方法)憔涉,HashTable則使用key的hashCode方法得到。
小編推薦一個(gè)學(xué)Java的學(xué)習(xí)裙【 六五零析苫,五五四兜叨,六零七 】穿扳,無論你是大牛還是小白,是想轉(zhuǎn)行還是想入行都可以來了解一起進(jìn)步一起學(xué)習(xí)国旷!裙內(nèi)有開發(fā)工具矛物,很多干貨和技術(shù)資料分享!
HashMap數(shù)據(jù)結(jié)構(gòu)模型
日常開發(fā)中的使用建議
如果在單線程的環(huán)境中建議使用HashMap议街,HashMap性能更好一些泽谨。
如果是多線程環(huán)境也不建議使用HashTable,而是使用ConcurrentHashMap特漩,ConcurrentHashMap也是線程安全的吧雹,并且比HashTable性能好。
HashMap在確定數(shù)據(jù)大小的情況想涂身,建議初始化一個(gè)合適的容量雄卷,否則可能會(huì)面resieze,resize操作是一個(gè)非常耗時(shí)的過程蛤售。
如果把自定以的類作為HashMap或者HashTable的key丁鹉,就需要重寫hashCode和equals方法。