需求背景:数据进行批量处理得时候,既要去重又要保留文本域中数据的顺序
解决方法:
1.新建一个工具类SetList
package util;
import java.util.LinkedList;
public class SetList<T> extends LinkedList<T> {
private static final long serialVersionUID = 3612971767507405567L;
@Override
public boolean add(T object){
if(size() == 0){
return super.add(object);
}else{
int count = 0;
for (T t : this){
if(t.equals(object)){
count ++;
break;
}
}
if (count == 0){
return super.add(object);
}else{
return false;
}
}
}
}
2.去重并保留原来的顺序
//去重并保留原来的顺序
public String[] distinctByArr(String[] arr){
if(arr != null && arr.length > 0){
SetList<String> setList = new SetList<>();
for(String str : arr){
setList.add(str);
}
String[] arr_new = new String[setList.size()];
for(int i=0;i<setList.size(); i++){
arr_new[i] = setList.get(i);
}
return arr_new;
}else{
return arr;
}
}