Java HashSet集合存儲(chǔ)遍歷學(xué)生對(duì)象代碼實(shí)例
由于Set集合是不存儲(chǔ)重復(fù)元素的,所以在做此案例時(shí),如果我正常添加一個(gè)重復(fù)元素是什么結(jié)果呢?
public class HashSetDemo { public static void main(String[] args) { //創(chuàng)建HashSet集合對(duì)象 HashSet<Student> hashSet = new HashSet<Student>(); //創(chuàng)建學(xué)生對(duì)象 Student s1 = new Student('愛學(xué)習(xí)', 21); Student s2 = new Student('愛Java', 22); Student s3 = new Student('堅(jiān)持不懈', 23); Student s4 = new Student('愛Java', 22); //把學(xué)生添加到集合 hashSet.add(s1); hashSet.add(s2); hashSet.add(s3); hashSet.add(s4); //遍歷集合(增強(qiáng)for循環(huán)) for (Student s : hashSet) { System.out.println(s.getName() + ',' + s.getAge()); } }}
運(yùn)行結(jié)果:
通過運(yùn)行結(jié)果,我們發(fā)現(xiàn),重復(fù)的元素仍然被添加進(jìn)去,是什么原因呢? 根據(jù)源碼分析和HashSet底層數(shù)據(jù)結(jié)構(gòu)可以知道,如果兩個(gè)對(duì)象的哈希值相同(hashCode方法),并且對(duì)象的內(nèi)容也相同(equals方法),是不會(huì)存儲(chǔ)在哈希表的。所以我們需要在被存儲(chǔ)的對(duì)象類中重寫hashCode方法和equals方法,來解決添加了重復(fù)元素的問題。
在對(duì)象類中重寫hashCode方法和equals方法后(自動(dòng)生成即可)運(yùn)行上面的代碼,運(yùn)行結(jié)果:
可見,重復(fù)的元素未被添加到集合。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)2. XML實(shí)體注入深入理解3. 不要在HTML中濫用div4. XML入門的常見問題(三)5. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera6. XML入門的常見問題(四)7. XML 非法字符(轉(zhuǎn)義字符)8. Xpath語(yǔ)法格式總結(jié)9. 前端html+css實(shí)現(xiàn)動(dòng)態(tài)生日快樂代碼10. JavaScript多級(jí)判定代碼優(yōu)化淺析
