EnumSet 類別

定義

用於列舉類型的特製化 Set 實作。

[Android.Runtime.Register("java/util/EnumSet", DoNotGenerateAcw=true)]
[Java.Interop.JavaTypeParameters(new System.String[] { "E extends java.lang.Enum<E>" })]
public abstract class EnumSet : Java.Util.AbstractSet, IDisposable, Java.Interop.IJavaPeerable, Java.IO.ISerializable, Java.Lang.ICloneable
[<Android.Runtime.Register("java/util/EnumSet", DoNotGenerateAcw=true)>]
[<Java.Interop.JavaTypeParameters(new System.String[] { "E extends java.lang.Enum<E>" })>]
type EnumSet = class
    inherit AbstractSet
    interface ISerializable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
    interface ICloneable
繼承
屬性
實作

備註

用於列舉類型的特製化 Set 實作。 列舉集中的所有專案都必須來自建立集合時,明確或隱含指定的單一列舉類型。 列舉集會在內部表示為位向量。 這種表示非常精簡且有效率。 此類別的空間和時間效能應該夠好,以允許其做為高品質的型別替代傳統 int 「位旗標」。 即使大量作業 (,例如 containsAllretainAll) ,如果引數也是列舉集,則應該非常快速地執行。

方法所 iterator 傳回的反覆運算器會依 其自然順序 周遊元素, (宣告列舉常數的順序) 。 傳回的反覆運算器弱 式一致:它永遠不會擲回 ConcurrentModificationException ,而且可能會或可能不會顯示反復專案進行時所發生之集合的任何修改效果。

不允許 Null 元素。 嘗試插入 Null 專案將會擲回 NullPointerException 。 不過,嘗試測試 Null 元素是否存在,或移除一個專案會正常運作。

就像大部分的集合實作一樣, EnumSet 不會同步處理。 如果多個執行緒同時存取列舉集,而且至少有一個執行緒修改集合,則應該在外部同步處理。 這通常是藉由在自然封裝列舉集的某些物件上進行同步處理來完成。 如果不存在這類物件,應該使用 Collections#synchronizedSet 方法「包裝」集合。 在建立期間最好這麼做,以防止意外的未同步存取:

Set&lt;MyEnum&gt; s = Collections.synchronizedSet(EnumSet.noneOf(MyEnum.class));

實作注意事項:所有基本作業都會以固定時間執行。 它們可能 (,但不保證) 比其 HashSet 對應專案更快。 即使大量作業在常數時間執行,如果引數也是列舉集。

這個類別是 JAVA Collections Framework的成員。

在 1.5 中新增。

java.util.EnumSet JAVA 檔。

此頁面的部分是根據所建立和共用的工作進行修改,並根據 2.5 屬性授權中所述的詞彙來使用。

建構函式

EnumSet(IntPtr, JniHandleOwnership)

建立 JNI 物件的 Managed 標記法時使用的建構函式;由執行時間呼叫。

屬性

Class

傳回這個 Object 的執行時間類別。

(繼承來源 Object)
Handle

基礎 Android 實例的控制碼。

(繼承來源 Object)
IsEmpty

要新增

(繼承來源 AbstractCollection)
JniIdentityHashCode

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
JniPeerMembers

用於列舉類型的特製化 Set 實作。

PeerReference

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
ThresholdClass

此 API 支援適用于 Android 的 Mono 基礎結構,並不適合直接從您的程式碼使用。

ThresholdType

此 API 支援適用于 Android 的 Mono 基礎結構,並不適合直接從您的程式碼使用。

方法

Add(Object)

要新增

(繼承來源 AbstractCollection)
AddAll(ICollection)

要新增

(繼承來源 AbstractCollection)
AllOf(Class)

建立列舉集,其中包含指定專案類型中的所有專案。

Clear()

要新增

(繼承來源 AbstractCollection)
Clone()

傳回這個集合的複本。

ComplementOf(EnumSet)

使用與指定列舉集相同的專案類型建立列舉集,一開始會包含此型別的所有 專案,但未 包含在指定集合中。

Contains(Object)

要新增

(繼承來源 AbstractCollection)
ContainsAll(ICollection)

要新增

(繼承來源 AbstractCollection)
CopyOf(EnumSet)

使用與指定列舉集相同的專案類型建立列舉集,一開始會在有任何) 時包含相同的專案 (。

CopyOf(ICollection)

建立從指定集合初始化的列舉集。

Dispose()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
Dispose(Boolean)

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
Equals(Object)

指出其他物件是否「等於」這個物件。

(繼承來源 Object)
GetHashCode()

傳回此物件的雜湊碼值。

(繼承來源 Object)
Iterator()

傳回這個集合中所含專案的反覆運算器。

(繼承來源 AbstractCollection)
JavaFinalize()

當垃圾收集判斷物件不再參考物件時,垃圾收集行程會在物件上呼叫。

(繼承來源 Object)
NoneOf(Class)

建立具有指定專案類型的空列舉集。

Notify()

喚醒正在等候此物件監視器的單一線程。

(繼承來源 Object)
NotifyAll()

喚醒正在等候此物件監視器的所有線程。

(繼承來源 Object)
Of(Object)

建立一開始包含指定專案的列舉集。

Of(Object, Object)

建立一開始包含指定專案的列舉集。

Of(Object, Object, Object)

建立一開始包含指定專案的列舉集。

Of(Object, Object, Object, Object)

建立一開始包含指定專案的列舉集。

Of(Object, Object, Object, Object, Object)

建立一開始包含指定專案的列舉集。

Of(Object, Object[])

建立一開始包含指定專案的列舉集。

Range(Object, Object)

建立列舉集,一開始包含兩個指定端點所定義之範圍中的所有專案。

Remove(Object)

要新增

(繼承來源 AbstractCollection)
RemoveAll(ICollection)

要新增

(繼承來源 AbstractCollection)
RetainAll(ICollection)

要新增

(繼承來源 AbstractCollection)
SetHandle(IntPtr, JniHandleOwnership)

設定 Handle 屬性。

(繼承來源 Object)
Size()

傳回這個 Collection 包含之物件的計數。

(繼承來源 AbstractCollection)
ToArray()

要新增

(繼承來源 AbstractCollection)
ToArray(Object[])

要新增

(繼承來源 AbstractCollection)
ToArray<T>()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
ToString()

傳回物件的字串表示。

(繼承來源 Object)
UnregisterFromRuntime()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
Wait()

讓目前的執行緒等到喚醒為止,通常是 em < notified/em > 或 < em > interrupted < /em > 。 ><

(繼承來源 Object)
Wait(Int64)

讓目前的執行緒等到喚醒為止,通常是 em < notified/em > 或 < em > interrupted < /em > ,或直到經過一定數量的即時為止。 <>

(繼承來源 Object)
Wait(Int64, Int32)

讓目前的執行緒等到喚醒為止,通常是 em < notified/em > 或 < em > interrupted < /em > ,或直到經過一定數量的即時為止。 <>

(繼承來源 Object)

明確介面實作

IJavaPeerable.Disposed()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.DisposeUnlessReferenced()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.Finalized()

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.JniManagedPeerState

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

用於列舉類型的特製化 Set 實作。

(繼承來源 Object)

擴充方法

JavaCast<TResult>(IJavaObject)

執行 Android 執行時間檢查的類型轉換。

JavaCast<TResult>(IJavaObject)

用於列舉類型的特製化 Set 實作。

GetJniTypeName(IJavaPeerable)

用於列舉類型的特製化 Set 實作。

ToEnumerable(IIterable)

用於列舉類型的特製化 Set 實作。

ToEnumerable<T>(IIterable)

用於列舉類型的特製化 Set 實作。

適用於