com.xiaoleilu.hutool.util.CollectionUtil Maven / Gradle / Ivy
package com.xiaoleilu.hutool.util;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.Deque;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.Stack;
import java.util.TreeSet;
import java.util.concurrent.CopyOnWriteArrayList;
import com.xiaoleilu.hutool.convert.Convert;
import com.xiaoleilu.hutool.lang.BoundedPriorityQueue;
import com.xiaoleilu.hutool.lang.Editor;
import com.xiaoleilu.hutool.lang.Matcher;
/**
* 集合相关工具类,包括数组
*
* @author xiaoleilu
*
*/
public final class CollectionUtil {
private CollectionUtil() {}
/**
* 两个集合的并集
* 针对一个集合中存在多个相同元素的情况,计算两个集合中此元素的个数,保留最多的个数
* 例如:集合1:[a, b, c, c, c],集合2:[a, b, c, c]
* 结果:[a, b, c, c, c],此结果中只保留了三个c
*
* @param 集合元素类型
* @param coll1 集合1
* @param coll2 集合2
* @return 并集的集合,返回 {@link ArrayList}
*/
public static Collection union(final Collection coll1, final Collection coll2) {
final ArrayList list = new ArrayList<>();
if (isEmpty(coll1)) {
list.addAll(coll2);
} else if (isEmpty(coll2)) {
list.addAll(coll1);
} else {
final Map map1 = countMap(coll1);
final Map map2 = countMap(coll2);
final Set elts = newHashSet(coll2);
for (T t : elts) {
for (int i = 0, m = Math.max(Convert.toInt(map1.get(t), 0), Convert.toInt(map2.get(t), 0)); i < m; i++) {
list.add(t);
}
}
}
return list;
}
/**
* 多个集合的并集
* 针对一个集合中存在多个相同元素的情况,计算两个集合中此元素的个数,保留最多的个数
* 例如:集合1:[a, b, c, c, c],集合2:[a, b, c, c]
* 结果:[a, b, c, c, c],此结果中只保留了三个c
*
* @param 集合元素类型
* @param coll1 集合1
* @param coll2 集合2
* @param otherColls 其它集合
* @return 并集的集合,返回 {@link ArrayList}
*/
@SafeVarargs
public static Collection union(final Collection coll1, final Collection coll2, final Collection... otherColls) {
Collection union = union(coll1, coll2);
for (Collection coll : otherColls) {
union = union(union, coll);
}
return union;
}
/**
* 两个集合的交集
* 针对一个集合中存在多个相同元素的情况,计算两个集合中此元素的个数,保留最少的个数
* 例如:集合1:[a, b, c, c, c],集合2:[a, b, c, c]
* 结果:[a, b, c, c],此结果中只保留了两个c
*
* @param 集合元素类型
* @param coll1 集合1
* @param coll2 集合2
* @return 交集的集合,返回 {@link ArrayList}
*/
public static Collection intersection(final Collection coll1, final Collection coll2) {
final ArrayList list = new ArrayList<>();
if (isNotEmpty(coll1) && isNotEmpty(coll2)) {
final Map map1 = countMap(coll1);
final Map map2 = countMap(coll2);
final Set elts = newHashSet(coll2);
for (T t : elts) {
for (int i = 0, m = Math.min(Convert.toInt(map1.get(t), 0), Convert.toInt(map2.get(t), 0)); i < m; i++) {
list.add(t);
}
}
}
return list;
}
/**
* 多个集合的交集
* 针对一个集合中存在多个相同元素的情况,计算两个集合中此元素的个数,保留最少的个数
* 例如:集合1:[a, b, c, c, c],集合2:[a, b, c, c]
* 结果:[a, b, c, c],此结果中只保留了两个c
*
* @param 集合元素类型
* @param coll1 集合1
* @param coll2 集合2
* @param otherColls 其它集合
* @return 并集的集合,返回 {@link ArrayList}
*/
@SafeVarargs
public static Collection intersection(final Collection coll1, final Collection coll2, final Collection... otherColls) {
Collection intersection = intersection(coll1, coll2);
if (isEmpty(intersection)) {
return intersection;
}
for (Collection coll : otherColls) {
intersection = intersection(intersection, coll);
if (isEmpty(intersection)) {
return intersection;
}
}
return intersection;
}
/**
* 两个集合的差集
* 针对一个集合中存在多个相同元素的情况,计算两个集合中此元素的个数,保留两个集合中此元素个数差的个数
* 例如:集合1:[a, b, c, c, c],集合2:[a, b, c, c]
* 结果:[c],此结果中只保留了一个
*
* @param 集合元素类型
* @param coll1 集合1
* @param coll2 集合2
* @return 差集的集合,返回 {@link ArrayList}
*/
public static Collection disjunction(final Collection coll1, final Collection coll2) {
final ArrayList list = new ArrayList<>();
if (isNotEmpty(coll1) && isNotEmpty(coll2)) {
final Map map1 = countMap(coll1);
final Map map2 = countMap(coll2);
final Set elts = newHashSet(coll2);
for (T t : elts) {
for (int i = 0, m = Math.max(Convert.toInt(map1.get(t), 0), Convert.toInt(map2.get(t), 0)) - Math.min(Convert.toInt(map1.get(t), 0), Convert.toInt(map2.get(t), 0)); i < m; i++) {
list.add(t);
}
}
}
return list;
}
/**
* 其中一个集合在另一个集合中是否至少包含一个元素,既是两个集合是否至少有一个共同的元素
*
* @param coll1 集合1
* @param coll2 集合2
* @return 其中一个集合在另一个集合中是否至少包含一个元素
* @since 2.1
* @see #intersection
*/
public static boolean containsAny(final Collection> coll1, final Collection> coll2) {
if (isEmpty(coll1) || isEmpty(coll2)) {
return false;
}
if (coll1.size() < coll2.size()) {
for (Object object : coll1) {
if (coll2.contains(object)) {
return true;
}
}
} else {
for (Object object : coll2) {
if (coll1.contains(object)) {
return true;
}
}
}
return false;
}
/**
* 根据集合返回一个元素计数的 {@link Map}
* 所谓元素计数就是假如这个集合中某个元素出现了n次,那将这个元素做为key,n做为value
* 例如:[a,b,c,c,c] 得到:
* a: 1
* b: 1
* c: 3
*
* @param 集合元素类型
* @param collection 集合
* @return {@link Map}
*/
public static Map countMap(Collection collection) {
HashMap countMap = new HashMap<>();
Integer count;
for (T t : collection) {
count = countMap.get(t);
if (null == count) {
countMap.put(t, 1);
} else {
countMap.put(t, count + 1);
}
}
return countMap;
}
/**
* 以 conjunction 为分隔符将集合转换为字符串
*
* @param 集合元素类型
* @param iterable {@link Iterable}
* @param conjunction 分隔符
* @return 连接后的字符串
*/
public static String join(Iterable iterable, CharSequence conjunction) {
if(null == iterable){
return null;
}
return join(iterable.iterator(), conjunction);
}
/**
* 以 conjunction 为分隔符将集合转换为字符串
*
* @param 集合元素类型
* @param iterator 集合
* @param conjunction 分隔符
* @return 连接后的字符串
*/
public static String join(Iterator iterator, CharSequence conjunction) {
if(null == iterator){
return null;
}
final StringBuilder sb = new StringBuilder();
boolean isFirst = true;
T item;
while(iterator.hasNext()){
if (isFirst) {
isFirst = false;
} else {
sb.append(conjunction);
}
item = iterator.next();
if(ArrayUtil.isArray(item)) {
sb.append(ArrayUtil.join(ArrayUtil.wrap(item), conjunction));
} else if(item instanceof Iterable>) {
sb.append(join((Iterable>)item, conjunction));
} else if(item instanceof Iterator>) {
sb.append(join((Iterator>)item, conjunction));
} else{
sb.append(item);
}
}
return sb.toString();
}
/**
* 将多个集合排序并显示不同的段落(分页)
*
* @param 集合元素类型
* @param pageNo 页码,从1开始
* @param numPerPage 每页的条目数
* @param comparator 比较器
* @param colls 集合数组
* @return 分页后的段落内容
*/
@SafeVarargs
public static List sortPageAll(int pageNo, int numPerPage, Comparator comparator, Collection... colls) {
final List result = new ArrayList<>();
for (Collection coll : colls) {
result.addAll(coll);
}
Collections.sort(result, comparator);
int resultSize = result.size();
// 每页条目数大于总数直接返回所有
if (resultSize <= numPerPage) {
return result;
}
final int[] startEnd = PageUtil.transToStartEnd(pageNo, numPerPage);
if (startEnd[1] > resultSize) {
// 越界直接返回空
return new ArrayList<>();
}
return result.subList(startEnd[0], startEnd[1]);
}
/**
* 将多个集合排序并显示不同的段落(分页)
*
* @param 集合元素类型
* @param pageNo 页码
* @param numPerPage 每页的条目数
* @param comparator 比较器
* @param colls 集合数组
* @return 分业后的段落内容
*/
@SafeVarargs
public static List sortPageAll2(int pageNo, int numPerPage, Comparator comparator, Collection... colls) {
BoundedPriorityQueue queue = new BoundedPriorityQueue<>(pageNo * numPerPage, comparator);
for (Collection coll : colls) {
queue.addAll(coll);
}
int resultSize = queue.size();
// 每页条目数大于总数直接返回所有
if (resultSize <= numPerPage) {
return queue.toList();
}
final int[] startEnd = PageUtil.transToStartEnd(pageNo, numPerPage);
if (startEnd[1] > resultSize) {
// 越界直接返回空
return new ArrayList<>();
}
return queue.toList().subList(startEnd[0], startEnd[1]);
}
/**
* 将Set排序(根据Entry的值)
*
* @param set 被排序的Set
* @return 排序后的Set
*/
public static List> sortEntrySetToList(Set> set) {
List> list = new LinkedList<>(set);
Collections.sort(list, new Comparator>(){
@Override
public int compare(Entry o1, Entry o2) {
if (o1.getValue() > o2.getValue()) {
return 1;
}
if (o1.getValue() < o2.getValue()) {
return -1;
}
return 0;
}
});
return list;
}
/**
* 切取部分数据
*
* @param 集合元素类型
* @param surplusAlaDatas 原数据
* @param partSize 每部分数据的长度
* @return 切取出的数据或null
*/
public static List popPart(Stack surplusAlaDatas, int partSize) {
if (isEmpty(surplusAlaDatas)) {
return null;
}
final List currentAlaDatas = new ArrayList<>();
int size = surplusAlaDatas.size();
// 切割
if (size > partSize) {
for (int i = 0; i < partSize; i++) {
currentAlaDatas.add(surplusAlaDatas.pop());
}
} else {
for (int i = 0; i < size; i++) {
currentAlaDatas.add(surplusAlaDatas.pop());
}
}
return currentAlaDatas;
}
/**
* 切取部分数据
*
* @param 集合元素类型
* @param surplusAlaDatas 原数据
* @param partSize 每部分数据的长度
* @return 切取出的数据或null
*/
public static List popPart(Deque surplusAlaDatas, int partSize) {
if (isEmpty(surplusAlaDatas)) {
return null;
}
final List currentAlaDatas = new ArrayList<>();
int size = surplusAlaDatas.size();
// 切割
if (size > partSize) {
for (int i = 0; i < partSize; i++) {
currentAlaDatas.add(surplusAlaDatas.pop());
}
} else {
for (int i = 0; i < size; i++) {
currentAlaDatas.add(surplusAlaDatas.pop());
}
}
return currentAlaDatas;
}
/**
* 新建一个HashMap
*
* @param Key类型
* @param Value类型
* @return HashMap对象
*/
public static HashMap newHashMap() {
return new HashMap();
}
/**
* 新建一个HashMap
*
* @param Key类型
* @param Value类型
* @param size 初始大小,由于默认负载因子0.75,传入的size会实际初始大小为size / 0.75
* @param isOrder Map的Key是否有序,有序返回 {@link LinkedHashMap},否则返回 {@link HashMap}
* @return HashMap对象
* @since 3.0.4
*/
public static HashMap newHashMap(int size, boolean isOrder) {
int initialCapacity = (int) (size / 0.75);
return isOrder ? new LinkedHashMap(initialCapacity) : new HashMap(initialCapacity);
}
/**
* 新建一个HashMap
*
* @param Key类型
* @param Value类型
* @param size 初始大小,由于默认负载因子0.75,传入的size会实际初始大小为size / 0.75
* @return HashMap对象
*/
public static HashMap newHashMap(int size) {
return newHashMap(size, false);
}
/**
* 新建一个HashSet
*
* @param 集合元素类型
* @param ts 元素数组
* @return HashSet对象
*/
@SafeVarargs
public static HashSet newHashSet(T... ts) {
HashSet set = new HashSet(Math.max((int) (ts.length/.75f) + 1, 16));
for (T t : ts) {
set.add(t);
}
return set;
}
/**
* 新建一个HashSet
*
* @param 集合元素类型
* @param isSorted 是否有序,有序返回 {@link LinkedHashSet},否则返回 {@link HashSet}
* @param ts 元素数组
* @return HashSet对象
*/
@SafeVarargs
public static HashSet newHashSet(boolean isSorted, T... ts) {
int initialCapacity = Math.max((int) (ts.length/.75f) + 1, 16);
HashSet set = isSorted ? new LinkedHashSet(initialCapacity) : new HashSet(initialCapacity);
for (T t : ts) {
set.add(t);
}
return set;
}
/**
* 新建一个HashSet
*
* @param 集合元素类型
* @param collection 集合
* @return HashSet对象
*/
public static HashSet newHashSet(Collection collection) {
return new HashSet(collection);
}
/**
* 新建一个HashSet
*
* @param 集合元素类型
* @param isSorted 是否有序,有序返回 {@link LinkedHashSet},否则返回{@link HashSet}
* @param collection 集合,用于初始化Set
* @return HashSet对象
*/
public static HashSet newHashSet(boolean isSorted, Collection collection) {
return isSorted ? new LinkedHashSet() : new HashSet(collection);
}
/**
* 新建一个ArrayList
*
* @param 集合元素类型
* @param values 数组
* @return ArrayList对象
*/
@SafeVarargs
public static ArrayList newArrayList(T... values) {
ArrayList arrayList = new ArrayList(values.length);
for (T t : values) {
arrayList.add(t);
}
return arrayList;
}
/**
* 新建一个ArrayList
*
* @param 集合元素类型
* @param collection 集合
* @return ArrayList对象
*/
public static ArrayList newArrayList(Collection collection) {
return new ArrayList(collection);
}
/**
* 新建一个CopyOnWriteArrayList
*
* @param 集合元素类型
* @param collection 集合
* @return {@link CopyOnWriteArrayList}
*/
public static CopyOnWriteArrayList newCopyOnWriteArrayList(Collection collection) {
return (null == collection) ? (new CopyOnWriteArrayList()) : (new CopyOnWriteArrayList(collection));
}
/**
* 去重集合
*
* @param 集合元素类型
* @param collection 集合
* @return {@link ArrayList}
*/
public static ArrayList distinct(Collection collection){
if(isEmpty(collection)){
return new ArrayList<>();
}else if(collection instanceof Set){
return new ArrayList<>(collection);
}else{
return new ArrayList<>(new LinkedHashSet<>(collection));
}
}
/**
* 截取数组的部分
*
* @param 集合元素类型
* @param list 被截取的数组
* @param start 开始位置(包含)
* @param end 结束位置(不包含)
* @return 截取后的数组,当开始位置超过最大时,返回null
*/
public static List sub(List list, int start, int end) {
if (list == null || list.isEmpty()) {
return null;
}
if (start < 0) {
start = 0;
}
if (end < 0) {
end = 0;
}
if (start > end) {
int tmp = start;
start = end;
end = tmp;
}
final int size = list.size();
if (end > size) {
if (start >= size) {
return null;
}
end = size;
}
return list.subList(start, end);
}
/**
* 截取集合的部分
*
* @param 集合元素类型
* @param list 被截取的数组
* @param start 开始位置(包含)
* @param end 结束位置(不包含)
* @return 截取后的数组,当开始位置超过最大时,返回null
*/
public static List sub(Collection list, int start, int end) {
if (list == null || list.isEmpty()) {
return null;
}
return sub(new ArrayList(list), start, end);
}
/**
* 对集合按照指定长度分段,每一个段为单独的集合,返回这个集合的列表
*
* @param 集合元素类型
* @param collection 集合
* @param size 每个段的长度
* @return 分段列表
*/
public static List> split(Collection collection, int size){
final List> result = new ArrayList<>();
ArrayList subList = new ArrayList<>(size);
for (T t : collection) {
if(subList.size() > size){
result.add(subList);
subList = new ArrayList<>(size);
}
subList.add(t);
}
result.add(subList);
return result;
}
/**
* 过滤
* 过滤会改变原集合的内容
*
* @param 集合元素类型
* @param collection 集合
* @param editor 编辑器接口
* @return 过滤后的数组
*/
public static Collection filter(Collection collection, Editor editor) {
Collection collection2 = ObjectUtil.clone(collection);
collection2.clear();
T modified;
for (T t : collection) {
modified = editor.edit(t);
if (null != modified) {
collection2.add(t);
}
}
return collection2;
}
/**
* 过滤
*
* @param Key类型
* @param Value类型
* @param map Map
* @param editor 编辑器接口
* @return 过滤后的Map
*/
public static Map filter(Map map, Editor> editor) {
Map map2 = ObjectUtil.clone(map);
map2.clear();
Entry modified;
for (Entry entry : map.entrySet()) {
modified = editor.edit(entry);
if (null != modified) {
map2.put(entry.getKey(), entry.getValue());
}
}
return map2;
}
/**
* 集合中匹配规则的数量
*
* @param 集合元素类型
* @param iterable {@link Iterable}
* @param matcher 匹配器,为空则全部匹配
* @return 匹配数量
*/
public static int count(Iterable iterable, Matcher matcher){
int count = 0;
for (T t : iterable) {
if(null == matcher || matcher.match(t)){
count++;
}
}
return count;
}
// ---------------------------------------------------------------------- isEmpty
/**
* 集合是否为空
*
* @param collection 集合
* @return 是否为空
*/
public static boolean isEmpty(Collection> collection) {
return collection == null || collection.isEmpty();
}
/**
* Map是否为空
*
* @param map 集合
* @return 是否为空
*/
public static boolean isEmpty(Map, ?> map) {
return map == null || map.isEmpty();
}
/**
* Iterable是否为空
*
* @param iterable Iterable对象
* @return 是否为空
*/
public static boolean isEmpty(Iterable> iterable) {
return null == iterable || isEmpty(iterable.iterator());
}
/**
* Iterator是否为空
*
* @param Iterator Iterator对象
* @return 是否为空
*/
public static boolean isEmpty(Iterator> Iterator) {
return null == Iterator || false == Iterator.hasNext();
}
/**
* Enumeration是否为空
*
* @param enumeration {@link Enumeration}
* @return 是否为空
*/
public static boolean isEmpty(Enumeration> enumeration) {
return null == enumeration || false == enumeration.hasMoreElements();
}
// ---------------------------------------------------------------------- isNotEmpty
/**
* 集合是否为非空
*
* @param collection 集合
* @return 是否为非空
*/
public static boolean isNotEmpty(Collection> collection) {
return false == isEmpty(collection);
}
/**
* Map是否为非空
*
* @param map 集合
* @return 是否为非空
*/
public static boolean isNotEmpty(Map, ?> map) {
return false == isEmpty(map);
}
/**
* Iterable是否为空
*
* @param iterable Iterable对象
* @return 是否为空
*/
public static boolean isNotEmpty(Iterable> iterable) {
return null != iterable && isNotEmpty(iterable.iterator());
}
/**
* Iterator是否为空
*
* @param Iterator Iterator对象
* @return 是否为空
*/
public static boolean isNotEmpty(Iterator> Iterator) {
return null != Iterator && Iterator.hasNext();
}
/**
* Enumeration是否为空
*
* @param enumeration {@link Enumeration}
* @return 是否为空
*/
public static boolean isNotEmpty(Enumeration> enumeration) {
return null != enumeration && enumeration.hasMoreElements();
}
/**
* 是否包含{@code null}元素
* @param iterable 被检查的Iterable对象
* @return 是否包含{@code null}元素
* @since 3.0.7
*/
public static boolean hasNull(Iterable> iterable){
if (isNotEmpty(iterable)) {
for (Object element : iterable) {
if (null == element) {
return true;
}
}
}
return false;
}
// ---------------------------------------------------------------------- zip
/**
* 映射键值(参考Python的zip()函数)
* 例如:
* keys = a,b,c,d
* values = 1,2,3,4
* delimiter = , 则得到的Map是 {a=1, b=2, c=3, d=4}
* 如果两个数组长度不同,则只对应最短部分
*
* @param keys 键列表
* @param values 值列表
* @param delimiter 分隔符
* @param isOrder 是否有序
* @return Map
* @since 3.0.4
*/
public static Map zip(String keys, String values, String delimiter, boolean isOrder) {
return ArrayUtil.zip(StrUtil.split(keys, delimiter), StrUtil.split(values, delimiter), isOrder);
}
/**
* 映射键值(参考Python的zip()函数),返回Map无序
* 例如:
* keys = a,b,c,d
* values = 1,2,3,4
* delimiter = , 则得到的Map是 {a=1, b=2, c=3, d=4}
* 如果两个数组长度不同,则只对应最短部分
*
* @param keys 键列表
* @param values 值列表
* @param delimiter 分隔符
* @return Map
*/
public static Map zip(String keys, String values, String delimiter) {
return zip(keys, values, delimiter, false);
}
/**
* 映射键值(参考Python的zip()函数)
* 例如:
* keys = [a,b,c,d]
* values = [1,2,3,4]
* 则得到的Map是 {a=1, b=2, c=3, d=4}
* 如果两个数组长度不同,则只对应最短部分
*
* @param 键类型
* @param 值类型
* @param keys 键列表
* @param values 值列表
* @return Map
*/
public static Map zip(Collection keys, Collection values) {
if (isEmpty(keys) || isEmpty(values)) {
return null;
}
final List keyList = new ArrayList(keys);
final List valueList = new ArrayList(values);
final int size = Math.min(keys.size(), values.size());
final Map map = new HashMap((int) (size / 0.75));
for (int i = 0; i < size; i++) {
map.put(keyList.get(i), valueList.get(i));
}
return map;
}
/**
* 将Entry集合转换为HashMap
*
* @param 键类型
* @param 值类型
* @param entryCollection entry集合
* @return Map
*/
public static HashMap toMap(Collection> entryCollection) {
HashMap map = new HashMap();
for (Entry entry : entryCollection) {
map.put(entry.getKey(), entry.getValue());
}
return map;
}
/**
* 将集合转换为排序后的TreeSet
*
* @param 集合元素类型
* @param collection 集合
* @param comparator 比较器
* @return treeSet
*/
public static TreeSet toTreeSet(Collection collection, Comparator comparator) {
final TreeSet treeSet = new TreeSet(comparator);
for (T t : collection) {
treeSet.add(t);
}
return treeSet;
}
/**
* 排序集合
*
* @param 集合元素类型
* @param collection 集合
* @param comparator 比较器
* @return treeSet
*/
public static List sort(Collection collection, Comparator comparator) {
List list = new ArrayList(collection);
Collections.sort(list, comparator);
return list;
}
/**
* Iterator转换为Enumeration
* Adapt the specified Iterator
to the Enumeration
interface.
*
* @param 集合元素类型
* @param iter {@link Iterator}
* @return {@link Enumeration}
*/
public static Enumeration asEnumeration(final Iterator iter) {
return new Enumeration(){
@Override
public boolean hasMoreElements() {
return iter.hasNext();
}
@Override
public E nextElement() {
return iter.next();
}
};
}
/**
* Enumeration转换为Iterator
* Adapt the specified Enumeration
to the Iterator
interface
*
* @param 集合元素类型
* @param e {@link Enumeration}
* @return {@link Iterator}
*/
public static Iterator asIterator(final Enumeration e) {
return new Iterator(){
@Override
public boolean hasNext() {
return e.hasMoreElements();
}
@Override
public E next() {
return e.nextElement();
}
@Override
public void remove() {
throw new UnsupportedOperationException();
}
};
}
/**
* 加入全部
*
* @param 集合元素类型
* @param collection 被加入的集合 {@link Collection}
* @param iterator 要加入的{@link Iterator}
* @return 原集合
*/
public static Collection addAll(Collection collection, Iterator iterator) {
if(null != collection && null != iterator){
while (iterator.hasNext()) {
collection.add(iterator.next());
}
}
return collection;
}
/**
* 加入全部
*
* @param 集合元素类型
* @param collection 被加入的集合 {@link Collection}
* @param iterable 要加入的内容{@link Iterable}
* @return 原集合
*/
public static Collection addAll(Collection collection, Iterable iterable) {
return addAll(collection, iterable.iterator());
}
/**
* 加入全部
*
* @param 集合元素类型
* @param collection 被加入的集合 {@link Collection}
* @param enumeration 要加入的内容{@link Enumeration}
* @return 原集合
*/
public static Collection addAll(Collection collection, Enumeration enumeration) {
if(null != collection && null != enumeration){
while (enumeration.hasMoreElements()) {
collection.add(enumeration.nextElement());
}
}
return collection;
}
/**
* 将另一个列表中的元素加入到列表中,如果列表中已经存在此元素则忽略之
*
* @param 集合元素类型
* @param list 列表
* @param otherList 其它列表
* @return 此列表
*/
public static List addAllIfNotContains(List list, List otherList){
for (T t : otherList) {
if(false == list.contains(t)){
list.add(t);
}
}
return list;
}
/**
* 获取集合的第一个元素
*
* @param 集合元素类型
* @param iterable {@link Iterable}
* @return 第一个元素
* @since 3.0.1
*/
public static T getFirst(Iterable iterable){
if(null != iterable){
return getFirst(iterable.iterator());
}
return null;
}
/**
* 获取集合的第一个元素
*
* @param 集合元素类型
* @param iterator {@link Iterator}
* @return 第一个元素
* @since 3.0.1
*/
public static T getFirst(Iterator iterator){
if(null != iterator && iterator.hasNext()){
return iterator.next();
}
return null;
}
//------------------------------------------------------------------------------------------------- sort
/**
* 针对List排序,排序会修改原List
* @param list 被排序的List
* @param c {@link Comparator}
* @return 原list
* @see Collections#sort(List, Comparator)
*/
public List