com.landawn.abacus.util.ImmutableSet Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of abacus-util-se Show documentation
Show all versions of abacus-util-se Show documentation
A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.
/*
* Copyright (C) 2016 HaiYang Li
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package com.landawn.abacus.util;
import java.util.Collection;
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.SortedSet;
// TODO: Auto-generated Javadoc
/**
* The Class ImmutableSet.
*
* @author Haiyang Li
* @param
* @since 0.8
*/
public class ImmutableSet extends ImmutableCollection implements Set {
/** The Constant EMPTY. */
@SuppressWarnings("rawtypes")
private static final ImmutableSet EMPTY = new ImmutableSet(Collections.EMPTY_SET);
/**
* Instantiates a new immutable set.
*
* @param set
*/
ImmutableSet(Set extends E> set) {
super(Collections.unmodifiableSet(set));
}
/**
*
* @param
* @return
*/
public static ImmutableSet empty() {
return EMPTY;
}
/**
*
* @param
* @param e
* @return
*/
public static ImmutableSet just(E e) {
return new ImmutableSet<>(Collections.singleton(e));
}
/**
*
* @param
* @param e
* @return
*/
public static ImmutableSet of(E e) {
return new ImmutableSet<>(Collections.singleton(e));
}
/**
*
* @param
* @param a
* @return
*/
@SafeVarargs
public static ImmutableSet of(E... a) {
if (N.isNullOrEmpty(a)) {
return empty();
}
return new ImmutableSet<>(N.asLinkedHashSet(a));
}
/**
*
* @param
* @param set the elements in this Set
are shared by the returned ImmutableSet.
* @return
*/
public static ImmutableSet of(final Set extends E> set) {
if (set == null) {
return empty();
} else if (set instanceof ImmutableSet) {
return (ImmutableSet) set;
}
return new ImmutableSet<>(set);
}
/**
*
* @param
* @param set
* @return
*/
public static ImmutableSet copyOf(final Collection extends E> set) {
if (N.isNullOrEmpty(set)) {
return empty();
}
return new ImmutableSet<>((set instanceof LinkedHashSet || set instanceof SortedSet) ? N.newLinkedHashSet(set) : N.newHashSet(set));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy