List列表使用HashSet实现数据去重小技巧

2021-06-09 10:06:52 浏览数 (4)

在数据库中,可以使用distinct来去重,不过加上distinct会影响一定的性能,所以在一些特殊情况,数据量不是很大的情况,可以利用java集合Set的特性,Set集合数据是不重复的来进行数据过滤

实例代码:进行数据过滤,不过因为HashSet数据是无序的,所以数据是不排序的

代码语言:javascript复制
public <T> List<T> distinctListBySet(List<T> list) {
	return new ArrayList<T>(new HashSet<T>(list));
}

上面代码进行了无序排序,下面这个代码进行有序去查:

代码语言:javascript复制
public <T> List<T> distinctListBySetOrder(List<T> originList) {
    List<T> newList = new ArrayList<T>();
    Set<T> sortSet = new HashSet<T>();
    for (T entity: originList) {
        if (sortSet.add(entity)) {
            newList.add(entity);
        }
    }
    return newList;
}

1 人点赞