xiejun
2024-11-01 80b6cbfc9c861469146318d0b3dd5f8b8b525b8a
Source/BladeX-Tool/blade-core-tool/src/main/java/org/springblade/core/tool/utils/CollectionUtil.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,177 @@
/*
 *      Copyright (c) 2018-2028, DreamLu All rights reserved.
 *
 *  Redistribution and use in source and binary forms, with or without
 *  modification, are permitted provided that the following conditions are met:
 *
 *  Redistributions of source code must retain the above copyright notice,
 *  this list of conditions and the following disclaimer.
 *  Redistributions in binary form must reproduce the above copyright
 *  notice, this list of conditions and the following disclaimer in the
 *  documentation and/or other materials provided with the distribution.
 *  Neither the name of the dreamlu.net developer nor the names of its
 *  contributors may be used to endorse or promote products derived from
 *  this software without specific prior written permission.
 *  Author: DreamLu å¢æ˜¥æ¢¦ (596392912@qq.com)
 */
package org.springblade.core.tool.utils;
import org.springframework.lang.Nullable;
import org.springframework.util.CollectionUtils;
import java.lang.reflect.Array;
import java.util.*;
import java.util.stream.Collectors;
/**
 * é›†åˆå·¥å…·ç±»
 *
 * @author L.cm
 */
public class CollectionUtil extends CollectionUtils {
   /**
    * Return {@code true} if the supplied Collection is not {@code null} or empty.
    * Otherwise, return {@code false}.
    *
    * @param collection the Collection to check
    * @return whether the given Collection is not empty
    */
   public static boolean isNotEmpty(@Nullable Collection<?> collection) {
      return !CollectionUtil.isEmpty(collection);
   }
   /**
    * Return {@code true} if the supplied Map is not {@code null} or empty.
    * Otherwise, return {@code false}.
    *
    * @param map the Map to check
    * @return whether the given Map is not empty
    */
   public static boolean isNotEmpty(@Nullable Map<?, ?> map) {
      return !CollectionUtil.isEmpty(map);
   }
   /**
    * Check whether the given Array contains the given element.
    *
    * @param array   the Array to check
    * @param element the element to look for
    * @param <T>     The generic tag
    * @return {@code true} if found, {@code false} else
    */
   public static <T> boolean contains(@Nullable T[] array, final T element) {
      if (array == null) {
         return false;
      }
      return Arrays.stream(array).anyMatch(x -> ObjectUtil.nullSafeEquals(x, element));
   }
   /**
    * Concatenates 2 arrays
    *
    * @param one   æ•°ç»„1
    * @param other æ•°ç»„2
    * @return æ–°æ•°ç»„
    */
   public static String[] concat(String[] one, String[] other) {
      return concat(one, other, String.class);
   }
   /**
    * Concatenates 2 arrays
    *
    * @param one   æ•°ç»„1
    * @param other æ•°ç»„2
    * @param clazz æ•°ç»„ç±»
    * @return æ–°æ•°ç»„
    */
   public static <T> T[] concat(T[] one, T[] other, Class<T> clazz) {
      T[] target = (T[]) Array.newInstance(clazz, one.length + other.length);
      System.arraycopy(one, 0, target, 0, one.length);
      System.arraycopy(other, 0, target, one.length, other.length);
      return target;
   }
   /**
    * å¯¹è±¡æ˜¯å¦ä¸ºæ•°ç»„对象
    *
    * @param obj å¯¹è±¡
    * @return æ˜¯å¦ä¸ºæ•°ç»„对象,如果为{@code null} è¿”回false
    */
   public static boolean isArray(Object obj) {
      if (null == obj) {
         return false;
      }
      return obj.getClass().isArray();
   }
   /**
    * ä¸å¯å˜ Set
    *
    * @param es  å¯¹è±¡
    * @param <E> æ³›åž‹
    * @return é›†åˆ
    */
   @SafeVarargs
   public static <E> Set<E> ofImmutableSet(E... es) {
      Objects.requireNonNull(es, "args es is null.");
      return Arrays.stream(es).collect(Collectors.toSet());
   }
   /**
    * ä¸å¯å˜ List
    *
    * @param es  å¯¹è±¡
    * @param <E> æ³›åž‹
    * @return é›†åˆ
    */
   @SafeVarargs
   public static <E> List<E> ofImmutableList(E... es) {
      Objects.requireNonNull(es, "args es is null.");
      return Arrays.stream(es).collect(Collectors.toList());
   }
   /**
    * Iterable è½¬æ¢ä¸ºList集合
    *
    * @param elements Iterable
    * @param <E>      æ³›åž‹
    * @return é›†åˆ
    */
   public static <E> List<E> toList(Iterable<E> elements) {
      Objects.requireNonNull(elements, "elements es is null.");
      if (elements instanceof Collection) {
         return new ArrayList((Collection) elements);
      }
      Iterator<E> iterator = elements.iterator();
      List<E> list = new ArrayList<>();
      while (iterator.hasNext()) {
         list.add(iterator.next());
      }
      return list;
   }
   /**
    * å°†key value æ•°ç»„转为 map
    *
    * @param keysValues key value æ•°ç»„
    * @param <K>        key
    * @param <V>        value
    * @return map é›†åˆ
    */
   public static <K, V> Map<K, V> toMap(Object... keysValues) {
      int kvLength = keysValues.length;
      if (kvLength % 2 != 0) {
         throw new IllegalArgumentException("wrong number of arguments for met, keysValues length can not be odd");
      }
      Map<K, V> keyValueMap = new HashMap<>(kvLength);
      for (int i = kvLength - 2; i >= 0; i -= 2) {
         Object key = keysValues[i];
         Object value = keysValues[i + 1];
         keyValueMap.put((K) key, (V) value);
      }
      return keyValueMap;
   }
}