Java List中數(shù)據(jù)的去重
list中數(shù)據(jù)的去重,通常使用將list轉(zhuǎn)換為set,簡(jiǎn)單直接,因?yàn)閟et集合的特點(diǎn)就是沒(méi)有重復(fù)的元素。需要考慮一下兩種情況:
1.List集合中的數(shù)據(jù)類(lèi)型是基本數(shù)據(jù)類(lèi)型
可以直接將list集合轉(zhuǎn)換成set,就會(huì)自動(dòng)去除重復(fù)的元素。
如下示例:
public class Test { public static void main(String[] args) { List list = new ArrayList(); list.add(11); list.add(12); list.add(13); list.add(14); list.add(15); list.add(11); System.out.println(list); Set set = new HashSet(); List newList = new ArrayList(); set.addAll(list); newList.addAll(set); System.out.println(newList); } }
2.List集合中存儲(chǔ)的數(shù)據(jù)類(lèi)型是對(duì)象類(lèi)型
需要在對(duì)象的實(shí)體類(lèi)中去重寫(xiě)equals()方法和hashCode()方法
public class People { private String name; private String phoneNumber; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPhoneNumber() { return phoneNumber; } public void setPhoneNumber(String phoneNumber) { this.phoneNumber = phoneNumber; } public People(String name, String phoneNumber) { super(); this.name = name; this.phoneNumber = phoneNumber; } @Override public String toString() { return "People{" + "name='" + name + ''' + ", phoneNumber='" + phoneNumber + ''' + '}'; } @Override public boolean equals(Object o) { People p = (People) o; return name.equals(p.name) && phoneNumber.equals(p.phoneNumber); } @Override public int hashCode() { String str = name + phoneNumber; return str.hashCode(); } } public static void main(String[] args) { List<People> listPeople = new ArrayList<People>(); listPeople.add(new People("張三", "11111")); listPeople.add(new People("張三", "22222")); listPeople.add(new People("李四", "33333")); listPeople.add(new People("張三", "22222")); Set<People> setData = new HashSet<People>(); setData.addAll(listPeople); System.out.println("list:" + listPeople.toString()); System.out.println("set:" + setData.toString()); }
最后,我們拿出String中的equals()方法和hashCode()方法源碼來(lái)加深認(rèn)識(shí):
equals()
public boolean equals(Object anObject) { if (this == anObject) { return true; } if (anObject instanceof String) { String anotherString = (String)anObject; int n = count; if (n == anotherString.count) { char v1[] = value; char v2[] = anotherString.value; int i = offset; int j = anotherString.offset; while (n-- != 0) { if (v1[i++] != v2[j++]) return false; } return true; } } return false; }
比較兩個(gè)對(duì)象時(shí),首先先去判斷兩個(gè)對(duì)象是否具有相同的地址,如果是同一個(gè)對(duì)象的引用,則直接放回true;如果地址不一樣,則證明不是引用同一個(gè)對(duì)象,接下來(lái)就是挨個(gè)去比較兩個(gè)字符串對(duì)象的內(nèi)容是否一致,完全相等返回true,否則false。
hashCode()
public int hashCode() { int h = hash; if (h == 0 && count > 0) { int off = offset; char val[] = value; int len = count; for (int i = 0; i < len; i++) { h = 31*h + val[off++]; } hash = h; } return h; }
hashCode()官方定義:
hashcode方法返回該對(duì)象的哈希碼值。支持該方法是為哈希表提供一些優(yōu)點(diǎn),例如,java.util.Hashtable 提供的哈希表。
hashCode 的常規(guī)協(xié)定是:
在 Java 應(yīng)用程序執(zhí)行期間,在同一對(duì)象上多次調(diào)用 hashCode 方法時(shí),必須一致地返回相同的整數(shù),前提是對(duì)象上 equals 比較中所用的信息沒(méi)有被修改。從某一應(yīng)用程序的一次執(zhí)行到同一應(yīng)用程序的另一次執(zhí)行,該整數(shù)無(wú)需保持一致。
如果根據(jù) equals(Object) 方法,兩個(gè)對(duì)象是相等的,那么在兩個(gè)對(duì)象中的每個(gè)對(duì)象上調(diào)用 hashCode 方法都必須生成相同的整數(shù)結(jié)果。
以下情況不是必需的:如果根據(jù) equals(java.lang.Object) 方法,兩個(gè)對(duì)象不相等,那么在兩個(gè)對(duì)象中的任一對(duì)象上調(diào)用 hashCode 方法必定會(huì)生成不同的整數(shù)結(jié)果。但是,程序員應(yīng)該知道,為不相等的對(duì)象生成不同整數(shù)結(jié)果可以提高哈希表的性能。
實(shí)際上,由 Object 類(lèi)定義的 hashCode 方法確實(shí)會(huì)針對(duì)不同的對(duì)象返回不同的整數(shù)。(這一般是通過(guò)將該對(duì)象的內(nèi)部地址轉(zhuǎn)換成一個(gè)整數(shù)來(lái)實(shí)現(xiàn)的,但是 JavaTM 編程語(yǔ)言不需要這種實(shí)現(xiàn)技巧。)
當(dāng)equals方法被重寫(xiě)時(shí),通常有必要重寫(xiě) hashCode 方法,以維護(hù) hashCode 方法的常規(guī)協(xié)定,該協(xié)定聲明相等對(duì)象必須具有相等的哈希碼。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- Java中對(duì)List去重 Stream去重的解決方法
- java list去重操作實(shí)現(xiàn)方式
- 如何實(shí)現(xiàn)java8 list按照元素的某個(gè)字段去重
- java中List對(duì)象列表實(shí)現(xiàn)去重或取出及排序的方法
- Java實(shí)現(xiàn)對(duì)兩個(gè)List快速去重并排序操作示例
- Java中List根據(jù)map的某個(gè)key去重的代碼
- java正則表達(dá)式實(shí)現(xiàn)提取需要的字符并放入數(shù)組【ArrayList數(shù)組去重復(fù)功能】
- Java中List集合對(duì)象去重及按屬性去重的8種方法
- java list去重操作實(shí)現(xiàn)方式
- Java中List集合去除重復(fù)數(shù)據(jù)的方法匯總
相關(guān)文章
Spring?Boot快速過(guò)濾出一次請(qǐng)求的所有日志
這篇文章主要介紹了Spring?Boot快速過(guò)濾出一次請(qǐng)求的所有日志,本文講述了如何使用MDC工具來(lái)快速過(guò)濾一次請(qǐng)求的所有日志,并通過(guò)裝飾器模式使得MDC工具在異步線程里也能生效,需要的朋友可以參考下2022-11-11SpringBoot的服務(wù)注冊(cè)與發(fā)現(xiàn)示例
本篇文章主要介紹了SpringBoot的服務(wù)注冊(cè)與發(fā)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05SpringBoot引入Redis報(bào)Redis?command?timed?out兩種異常情況
這篇文章主要給大家介紹了關(guān)于SpringBoot引入Redis報(bào)Redis?command?timed?out兩種異常情況的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08Java RPC框架如何實(shí)現(xiàn)客戶(hù)端限流配置
這篇文章主要介紹了Java RPC框架如何實(shí)現(xiàn)客戶(hù)端限流配置,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02詳解Java如何使用責(zé)任鏈默認(rèn)優(yōu)雅地進(jìn)行參數(shù)校驗(yàn)
項(xiàng)目中參數(shù)校驗(yàn)十分重要,它可以保護(hù)我們應(yīng)用程序的安全性和合法性。這篇文章主要介紹了如何使用責(zé)任鏈默認(rèn)優(yōu)雅地進(jìn)行參數(shù)校驗(yàn),需要的可以參考一下2023-03-03Java Web端程序?qū)崿F(xiàn)文件下載的方法分享
這篇文章主要介紹了Java Web端程序?qū)崿F(xiàn)文件下載的方法分享,包括一個(gè)包含防盜鏈功能的專(zhuān)門(mén)針對(duì)圖片下載的程序代碼示例,需要的朋友可以參考下2016-05-05public?static?void?main(String[]?args)使用解讀
這篇文章主要介紹了public?static?void?main(String[]?args)的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01springmvc 中dao層和service層的區(qū)別說(shuō)明
這篇文章主要介紹了springmvc 中dao層和service層的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08