All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.power.common.util.CollectionUtil Maven / Gradle / Ivy

package com.power.common.util;

import java.util.*;

/**
 * @author yu
 * @since JDK 1.7+
 */
public class CollectionUtil {

	/**
	 * 
	 * isNotEmpty:(检查集合是否为空,不为空返回true)
	 * @param  type of param
	 * @param c collection
	 * @return boolean
	 */
	public static  boolean isNotEmpty(Collection c){
		if(c != null && c.size() != 0){
			return true;
		}else{
			return false;
		}
	}
	
	
	/**
	 * 
	 * checkEmpty:(检查集合是否为空,为空返回true)
	 * @param  type of param
	 * @param c collection
	 * @return boolean
	 */
	public static   boolean isEmpty(Collection c){
		if(c == null || c.size() == 0){
			return true;
		}else{
			return false;
		}
	}

	/**
	 * 该sublist增加了下标检测,避免报错
	 * @param  type of param
	 * @param source List
	 * @param from   from index
	 * @param to     to index
	 * @return list
	 */
	public static  List subList(List source, int from, int to) {
		if (CollectionUtil.isEmpty(source)) {
			return null;
		}
		int size = source.size();
		if (to > size) {
			return source.subList(from, size);
		} else {
			return source.subList(from, to);
		}
	}

	/**
	 * 将数组转换为List,如果数组为空则返回一个空list
	 * @param  type of param
	 * @param a object array
	 * @return List
	 */
	public static  List asList(T... a) {
		if (null != a) {
			return Arrays.asList(a);
		} else {
			return new ArrayList<>(0);
		}
	}


	/**
	 * 较差合并两个list的各项值交叉合并,合并有先后顺序,对于集合数据不为空的情况,
	 * result1的值第一个值放最前面
	 * @param  type of param
	 * @param result1 first of list
	 * @param result2 second of list
	 * @return List
	 */
	public static  List mergeAndSwap(List result1, List result2) {

		//两个数据都为空,则返回空的结合
		if (CollectionUtil.isEmpty(result1) && CollectionUtil.isEmpty(result2)) {
			return new ArrayList<>(0);
		}

		//近使用result2的结果,无需合并
		if (CollectionUtil.isEmpty(result1) && CollectionUtil.isNotEmpty(result2)) {
			return result2;
		}

		//仅仅使用result1的结果,无需合并
		if (CollectionUtil.isNotEmpty(result1) && CollectionUtil.isEmpty(result2)) {
			return result1;
		}

		int a = result1.size();
		int b = result2.size();
		int size = a + b;
		//两个list的值交叉合并算法(暂时未经过测试)
		List finalResult = new ArrayList<>(size);
		if (a >= b) {
			for (int i = 0; i < size; i++) {
				if (i > (b << 1) - 1) {
					finalResult.add(result1.get(i - b));
				} else {
					if ((i & 1) == 0 && i >> 1 < a) {
						finalResult.add(result1.get(i >> 1));
					}
				}
				if ((i & 1) == 1 && (i - 1) >> 1 < b) {
					finalResult.add(result2.get((i - 1) >> 1));
				}
			}
		} else {
			for (int i = 0; i < size; i++) {
				if ((i & 1) == 0 && (i >> 1) < a) {
					finalResult.add(result1.get(i >> 1));
				}
				if ((i & 1) == 1 && (i >> 1) < a - 1) {
					finalResult.add(result2.get((i - 1) >> 1));
				}
				if (i >= (a << 1) - 1) {
					finalResult.add(result2.get(i - a));
				}
			}
		}
		return finalResult;
	}

	/**
	 * split list
	 * @param  type of param
	 * @param list data of list
	 * @param pageSize page size
	 * @return List
	 */
	public static  List> splitList(List list, int pageSize) {
		List> listArray = new ArrayList<>();
		if(list != null && list.size()>0){
			int listSize = list.size();
			int page = (listSize + (pageSize-1))/ pageSize;
			for(int i=0;i subList = new ArrayList<>();
				for(int j=0;j> filterEmpty(List> list, String... exceptKeys) {
		List> tempList = new ArrayList<>();
		for (Map map : list) {
			int a = map.size();
			int counter = 0;
			for (Map.Entry entry : map.entrySet()) {
				for(String str:exceptKeys){
					if (!entry.getKey().equals(str)) {
						Object value = entry.getValue();
						if (value instanceof String) {
							if (StringUtil.isEmpty(String.valueOf(value))) {
								counter++;
							}
						} else {
							if (null == value) {
								counter++;
							}
						}
					}
				}
			}
			if (counter < a - exceptKeys.length) {
				tempList.add(map);
			}
		}
		return tempList;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy