激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java判斷2個(gè)List集合是否相等(不考慮元素的順序)

Java判斷2個(gè)List集合是否相等(不考慮元素的順序)

2021-06-06 14:53李學(xué)凱 Java教程

今天小編就為大家分享一篇關(guān)于Java判斷2個(gè)List集合是否相等(不考慮元素的順序)的文章,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

現(xiàn)在有兩個(gè)對(duì)象,他們的一個(gè)屬性是list,很明顯兩個(gè)對(duì)象的list里面的對(duì)象,都是相等的,只是這2個(gè)list里面的順序不一致,導(dǎo)致這2個(gè)對(duì)象被判斷為不相等啦,這就是問題,現(xiàn)在要解決這個(gè)問題。

問題圖如下:

Java判斷2個(gè)List集合是否相等(不考慮元素的順序)

可以看到這2個(gè)對(duì)象的呢個(gè)list屬性里面數(shù)據(jù),咱看起來是一樣的,但是經(jīng)過equals之后,返回的是false。

所以,需要自己重寫equals方法和hashcode方法,這2個(gè)方法一般是一起重寫的。

然后,問題的關(guān)鍵就在于,怎么判斷2個(gè)list集合是否相等。不考慮順序。

看代碼:

先是這2個(gè)對(duì)象的代碼

tablemetadata

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package com.lxk.model;
import lombok.allargsconstructor;
import lombok.data;
import lombok.noargsconstructor;
import java.util.collection;
import java.util.objects;
/**
 * table metadata.
 *
 * @author lxk
 */
@data
@allargsconstructor
@noargsconstructor
public class tablemetadata {
  private collection<columnmetadata> columnmetadata;
  @override
  public boolean equals(object o) {
    if (this == o) {
      return true;
    }
    if (o == null || getclass() != o.getclass()) {
      return false;
    }
    tablemetadata that = (tablemetadata) o;
    if (columnmetadata.size() != that.getcolumnmetadata().size()) {
      return false;
    }
    return columnmetadata.containsall(that.getcolumnmetadata());
  }
  @override
  public int hashcode() {
    return objects.hash(columnmetadata);
  }
}

然后是,list里面裝的對(duì)象的代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
package com.lxk.model;
import lombok.allargsconstructor;
import lombok.data;
import lombok.noargsconstructor;
import java.util.objects;
/**
 * column metadata.
 *
 * @author lxk
 */
@data
@noargsconstructor
@allargsconstructor
public final class columnmetadata {
  private string columnname;
  private string columntype;
  private boolean primarykey;
  @override
  public boolean equals(object o) {
    if (this == o) {
      return true;
    }
    if (o == null || getclass() != o.getclass()) {
      return false;
    }
    columnmetadata that = (columnmetadata) o;
    return primarykey == that.primarykey &&
        objects.equals(columnname, that.columnname) &&
        objects.equals(columntype, that.columntype);
  }
  @override
  public int hashcode() {
    return objects.hash(columnname, columntype, primarykey);
  }
  @override
  public string tostring() {
    return "columnmetadata{" +
        "columnname='" + columnname + '\'' +
        ", columntype='" + columntype + '\'' +
        ", primarykey=" + primarykey +
        '}';
  }
}

最后就是main方法啦

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package com.lxk.commontest;
import com.google.common.collect.lists;
import com.lxk.model.columnmetadata;
import com.lxk.model.tablemetadata;
import java.util.collection;
/**
 * 測(cè)試equals的各種情況
 *
 * @author lxk on 2018/9/17
 */
public class equalstest {
  public static void main(string[] args) {
    testcollectionequal();
  }
  /**
   * 比較2個(gè)集合是否是相同的,不考慮集合的順序,只要里面的元素確實(shí)相同即可。
   */
  private static void testcollectionequal() {
    columnmetadata c1 = new columnmetadata("age1", "name", true);
    columnmetadata c2 = new columnmetadata("age2", "name", true);
    columnmetadata c3 = new columnmetadata("age3", "name", true);
    columnmetadata c4 = new columnmetadata("age4", "name", true);
    collection<columnmetadata> list1 = lists.newarraylist(c1, c2, c3);
    collection<columnmetadata> list2 = lists.newarraylist(c2, c3, c1);
    tablemetadata table1 = new tablemetadata(list1);
    tablemetadata table2 = new tablemetadata(list2);
    boolean equals = table1.equals(table2);
    system.out.println(equals);
  }
}

如上操作之后,這個(gè)判斷就可以得到2個(gè)對(duì)象,是真的相等啦,不會(huì)因?yàn)閘ist里面值的順序不一致,而返回false啦。

Java判斷2個(gè)List集合是否相等(不考慮元素的順序)

這個(gè)問題簡(jiǎn)單嗎,簡(jiǎn)單就簡(jiǎn)單吧,我就喜歡簡(jiǎn)單的問題。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)服務(wù)器之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

原文鏈接:https://blog.csdn.net/qq_27093465/article/details/82777139

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美成人精品一区二区 | 九九热在线视频免费观看 | 一级免费特黄视频 | 亚洲导航深夜福利涩涩屋 | 91精品国产91久久久 | 99精品欧美一区二区 | 成人黄色免费 | 黄色高清视频网站 | 日日狠狠久久 | 草莓视频在线导航 | 日韩毛片网 | 91精品久久香蕉国产线看观看 | 免费亚洲视频在线观看 | 国产一区二区三区色淫影院 | 亚洲欧美日韩精品久久亚洲区 | 成人短视频在线观看免费 | 99国产精品欲a | 在线观看视频毛片 | 成人在线影视 | 午夜小电影 | 久久久久久久一区二区三区 | 原来神马影院手机版免费 | 免费国产一级淫片 | 精品国产视频一区二区三区 | 五月婷六月丁香狠狠躁狠狠爱 | 91网视频 | 国产一级αv片免费观看 | 亚洲成年人免费网站 | 成人免费在线播放 | 亚洲第一页中文字幕 | 免费播放av| 国产精品99久久久久久久 | 免费午夜视频在线观看 | 久久91精品 | 亚洲一级成人 | 黑人操穴 | 日韩精品久久久久久久电影99爱 | 成人网在线观看 | 免费在线观看成人av | 久久新地址 | 91高清国产视频 |