java中的接口是类吗
296
2023-03-09
阅读EnumSet抽象类源码
EnumSet
EnumSet是java枚举类型的泛型容器,Java既然有了SortedSet、TreeSet、HashSet等容器,为何还要多一个EnumSet
专门为枚举类设计的集合类,所有元素必须是枚举类型
EnumSet的集合元素是有序的,内部以位向量的形成存储,因此占用内存小,效率高
不允许加入null元素
源码
package java.util;
import sun.misc.SharedSecrets;
public abstract class EnumSet
implements Cloneable, java.io.Serializable
{
/**
* 元素类型
*/
final Class
/**
* 通过数组存储元素
*/
final Enum[] universe;
private static Enum[] ZERO_LENGTH_ENUM_ARRAY = new Enum[0];
EnumSet(Class
this.elementType = elementType;
this.universe = universe;
}
/**
* 创造一个空的 enum set 并制定其元素类型
* @param elementType the class object of the element type for this enum
* set
* @throws NullPointerException if elementType is null
*/
public static
Enum[] universe = getUniverse(elementType);
if (universe == null)
throw new ClassCastException(elementType + " not an enum");
if (universe.length <= 64)
return new RegularEnumSet<>(elementType, universe);
else
return new JumboEnumSet<>(elementType, universe);
}
/**
* 创建一个包含所有在指定元素类型的元素的枚举set
*
* @param elementType the class object of the element type for this enum
* set
* @throws NullPointerException if elementType is null
*/
public static
EnumSet
result.addAll();
return result;
}
/**
* Adds all of the elements from the appropriate enum type to this enum
* set, which is empty prior to the call.
*/
abstract void LEExVIaddAll();
/**
* 创建一个枚举设置相同的元素类型与指定枚举set
*
* @param s the enum set from which to initialize this enum set
* @throws NullPointerException if s is null
*/
public static
return s.clone();
}
/**
* 创建一个枚举集从指定集合初始化,最初包含相同的元素
* @param c the collection from which to initialize this enum set
* @throws IllegalArgumentException if c is not an
* EnumSet instance and contains no elements
* @throws NullPointerException if c is null
*/
public static
if (c instanceof EnumSet) {
return ((EnumSet
} else {
if (c.isEmpty())
throw new IllegalArgumentException("Collection is empty");
Iterator
E first = i.next();
EnumSet
while (i.hasNext())
result.add(i.next());
return result;
}
}
/**
* 创建一个枚举集合,其元素与 s 相同
* @param s the enum set from whose complement to initialize this enum set
* @throws NullPointerException if s is null
*/
public static
EnumSet
result.complement();
return result;
}
/**
* 1 个元素枚举集合
*
* @param e the element that this set is to contain initially
* @throws NullPointerException if e is null
* @return an enum set initially containing the specified element
*/
public static
EnumSet
result.add(e);
return result;
}
/**
* 2 个元素枚举集合
*
* @param e1 an element that this set is to contain initially
* @param e2 another element that this set is to contain initially
* @throws NullPointerException if any parameters are null
* @return an enum set initially containing the specified elements
*/
public static
EnumSet
result.add(e1);
result.add(e2);
return result;
}
/**
* 3 个元素枚举集合
*
* @param e1 an element that this set is to contain initially
* @param e2 another element that this set is to contain initially
* @param e3 another element that this set is to contain initially
* @throws NullPointerException if any parameters are null
* @return an enum set initially containing the specified elements
*/
public static
EnumSet
result.add(e1);
result.add(e2);
result.add(e3);
return result;
}
/**
* 4 个元素枚举集合
* @param e1 an element that this set is to contain initially
* @param e2 another element that this set is to contain initially
* @param e3 another element that this set is to contain initially
* @param e4 another element that this set is to contain initially
* @throws NullPointerException if any parameters are null
* @return an enum set initiallyhttp:// containing the specified elements
*/
public static
EnumSet
result.add(e1);
result.add(e2);
result.add(e3);
result.add(e4);
return result;
}
/**
* 5 个元素枚举集合
*
* @param e1 an element that this set is to contain initially
* @param e2 another element that this set is to contain initially
* @param e3 another element that this set is to contain initially
* @param e4 another element that this set is to contain initially
* @param e5 another element that this set is to contain initially
* @throws NullPointerException if any parameters are null
* @return an enum set initially containing the specified elements
*/
public static
E e5)
{
EnumSet
result.add(e1);
result.add(e2);
result.add(e3);
result.add(e4);
result.add(e5);
return result;
}
/**
* n 个元素枚举集合
*
* @param first an element that the set is to contain initially
* @param rest the remaining elements the set is to contain initially
* @throws NullPointerException if any of the specified elements are null,
* or if rest is null
* @return an enum set initially containing the specified elements
*/
@SafeVarargs
public static
EnumSet
result.add(first);
for (E e : rest)
result.add(e);
return result;
}
/**
* 区间内元素的 枚举集合
*
* @param from the first element in the range
* @param to the last element in the range
* @throws NullPointerException if {@code from} or {@code to} are null
* @throws IllegalArgumentException if {@code from.compareTo(to) > 0}
* @return an enum set initially containing all of the elements in the
* range defined by the two specified endpoints
*/
public static
if (from.compareTo(to) > 0)
throw new IllegalArgumentException(from + " > " + to);
EnumSet
result.addRange(from, to);
return result;
}
/**
* Adds the specified range to this enum set, which is empty prior
* to the call.
*/
abstract void addRange(E from, E to);
/**
* Returns a copy of this set.
*
* @return a copy of this set
*/
public EnumSet
try {
return (EnumSet
} catch(CloneNotSupportedException e) {
throw new AssertionError(e);
}
}
/**
* Complements the contents of this enum set.
*/
abstract void complement();
/**
* Throws an exception if e is not of the correct type for this enum set.
*/
final void typeCheck(E e) {
Class eClass = e.getClass();
if (eClass != elementType && eClass.getSuperclass() != elementType)
throw new ClassCastException(eClass + " != " + elementType);
}
/**
* Returns all of the values comprising E.
* The result is uncloned, cached, and shared by all callers.
*/
private static
return SharedSecrets.getJavaLangAccess()
.getEnumConstantsShared(elementType);
}
/**
* This class is used to serialize all EnumSet instances, regardless of
* implementation type. It captures their "logical contents" and they
* are reconstructed using public static factories. This is necessary
* to ensure that the existence of a particular implementation type is
* an implementation detail.
*
* @serial include
*/
private static class SerializationProxy
implements java.io.Serializable
{
/**
* The element type of this enum set.
*
* @serial
*/
private final Class
/**
* The elements contained in this enum set.
*
* @serial
*/
private final Enum[] elements;
SerializationProxy(EnumSet
elementType = set.elementType;
elements = set.toArray(ZERO_LENGTH_ENUM_ARRAY);
}
private Object readResolve() {
EnumSet
for (Enum e : elements)
result.add((E)e);
return result;
}
private static final long serialVersionUID = 362491234563181265L;
}
Object writeReplace() {
return new SerializationProxy<>(this);
}
// readObject method for the serialization proxy pattern
// See Effective Java, Second Ed., Item 78.
private void readObject(java.io.ObjectInputStream stream)
throws java.io.InvalidObjectException {
throw new java.io.InvalidObjectException("Proxy required");
}
}
总结
以上就是本文关于阅读EnumSet抽象类源码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~