Java Collection Contain containsSame(Collection first, Collection second)

Here you can find the source of containsSame(Collection first, Collection second)

Description

Checks if the given two Collection s contains the same elements in any order.

License

Open Source License

Parameter

Parameter Description
first The first Collection .
second The second Collection .

Return

true both s contains same elements, false s are different.

Declaration

public static <T> boolean containsSame(Collection<T> first, Collection<T> second) 

Method Source Code

//package com.java2s;
/*******************************************************************************
 * Copyright (c) 2014 Karlsruhe Institute of Technology, Germany
 *                    Technical University Darmstadt, Germany
 *                    Chalmers University of Technology, Sweden
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:// w ww  .ja  v a  2s .co m
 *    Technical University Darmstadt - initial API and implementation and/or initial documentation
 *******************************************************************************/

import java.util.Collection;
import java.util.Iterator;

import java.util.LinkedList;

public class Main {
    /**
     * <p>
     * Checks if the given two {@link Collection}s contains the same elements
     * in any order.
     * </p>
     * <p>
     * Empty {@link Collection}s and {@code null} parameters are treated as equal.
     * </p> 
     * @param first The first {@link Collection}.
     * @param second The second {@link Collection}.
     * @return {@code true} both {@link Collection}s contains same elements, {@code false} {@link Collection}s are different.
     */
    public static <T> boolean containsSame(Collection<T> first, Collection<T> second) {
        if (first != null) {
            if (second != null) {
                if (first.size() == second.size()) {
                    Collection<T> firstCopy = new LinkedList<T>(first);
                    boolean same = true;
                    Iterator<T> secondIter = second.iterator();
                    while (same && secondIter.hasNext()) {
                        T secondNext = secondIter.next();
                        same = firstCopy.remove(secondNext);
                    }
                    return same;
                } else {
                    return false;
                }
            } else {
                return first.size() == 0;
            }
        } else {
            return second == null || second.size() == 0;
        }
    }
}

Related

  1. containsObjectIdentity(Collection collection, Object object)
  2. containsOne(final Collection sup, final Collection parts)
  3. containsPrefix(final Collection words, final String prefix)
  4. containsPrefix(String str, Collection prefixes)
  5. containsSafe(Collection collection, V value)
  6. containsSameItems(Collection col1, Collection col2)
  7. containsSameType(Object o, Collection collection)
  8. containsSome(Collection source, Collection target)
  9. containsSome(final Collection c1, final Collection c2)