Java tutorial
/******************************************************************************* * Copyright (c) 2005, 2014 springside.github.io * * Licensed under the Apache License, Version 2.0 (the "License"); *******************************************************************************/ package com.nwtx.manager.common.utils; import org.apache.commons.lang3.StringUtils; import java.util.*; /** * ?springside */ /** * Collections. * * JDKCollectionsGuavaCollections2?, ??Collections3. * * ????????Apache Commons Collection, ?? * * @author calvin */ public class Collections3 { /** * ?Collection(toString())String, separator */ public static String convertToString(final Collection<?> collection, final String separator) { return StringUtils.join(collection, separator); } /** * ?Collection(toString())String, ???prefix??postfix * <div>mymessage</div> */ public static String convertToString(final Collection<?> collection, final String prefix, final String postfix) { StringBuilder builder = new StringBuilder(); for (Object o : collection) { builder.append(prefix).append(o).append(postfix); } return builder.toString(); } /** * ?. */ public static boolean isEmpty(Collection<?> collection) { return (collection == null) || collection.isEmpty(); } /** * ?. */ public static boolean isEmpty(Map<?, ?> map) { return (map == null) || map.isEmpty(); } /** * ?. */ public static boolean isNotEmpty(Collection<?> collection) { return (collection != null) && !(collection.isEmpty()); } /** * ?Collectioncollectionnull. */ public static <T> T getFirst(Collection<T> collection) { if (isEmpty(collection)) { return null; } return collection.iterator().next(); } /** * ?Collection? collectionnull. */ public static <T> T getLast(Collection<T> collection) { if (isEmpty(collection)) { return null; } // List?? if (collection instanceof List) { List<T> list = (List<T>) collection; return list.get(list.size() - 1); } // iterator?. Iterator<T> iterator = collection.iterator(); while (true) { T current = iterator.next(); if (!iterator.hasNext()) { return current; } } } /** * a+bList. */ public static <T> List<T> union(final Collection<T> a, final Collection<T> b) { List<T> result = new ArrayList<T>(a); result.addAll(b); return result; } /** * a-bList. */ public static <T> List<T> subtract(final Collection<T> a, final Collection<T> b) { List<T> list = new ArrayList<T>(a); for (T element : b) { list.remove(element); } return list; } /** * abList. */ public static <T> List<T> intersection(Collection<T> a, Collection<T> b) { List<T> list = new ArrayList<T>(); for (T element : a) { if (b.contains(element)) { list.add(element); } } return list; } }