亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#創建安全的棧(Stack)存儲結構

2020-01-24 00:57:45
字體:
來源:轉載
供稿:網友

   在C#中,用于存儲的結構較多,如:DataTable,DataSet,List,Dictionary,Stack等結構,各種結構采用的存儲的方式存在差異,效率也必然各有優缺點?,F在介紹一種后進先出的數據結構。

   談到存儲結構,我們在項目中使用的較多。對于Task存儲結構,棧與隊列是類似的結構,在使用的時候采用不同的方法。C#中棧(Stack)是編譯期間就分配好的內存空間,因此你的代碼中必須就棧的大小有明確的定義;堆是程序運行期間動態分配的內存空間,你可以根據程序的運行情況確定要分配的堆內存的大小。

    在C#中,棧通常保存著我們代碼執行的步驟。C#中的引用類型存儲在棧中,在程序運行的時候,每個線程(Thread)都會維護一個自己的專屬線程堆棧。當一個方法被調用的時候,主線程開始在所屬程序集的元數據中,查找被調用方法,然后通過JIT即時編譯并把結果(一般是本地CPU指令)放在棧頂。CPU通過總線從棧頂取指令,驅動程序以執行下去。

    以上對棧這個數據結構進行了一個簡單的介紹,現在看一下C#實現棧結構的底層方法:

  /// <summary>  /// 初始化 <see cref="T:System.Collections.Generic.Stack`1"/> 類的新實例,該實例為空并且具有默認初始容量。  /// </summary>  [__DynamicallyInvokable]  public Stack();  /// <summary>  /// 初始化 <see cref="T:System.Collections.Generic.Stack`1"/> 類的新實例,該實例為空,具有指定的初始容量或默認的初始容量(其中較大的一個)。  /// </summary>  /// <param name="capacity"><see cref="T:System.Collections.Generic.Stack`1"/> 可包含的初始元素數。</param><exception cref="T:System.ArgumentOutOfRangeException"><paramref name="capacity"/> is less than zero.</exception>  [__DynamicallyInvokable]  public Stack(int capacity);  /// <summary>  /// 初始化 <see cref="T:System.Collections.Generic.Stack`1"/> 類的新實例,該實例包含從指定集合復制的元素并且具有足夠的容量來容納所復制的元素。  /// </summary>  /// <param name="collection">從中復制元素的集合。</param><exception cref="T:System.ArgumentNullException"><paramref name="collection"/> is null.</exception>  [__DynamicallyInvokable]  public Stack(IEnumerable<T> collection);

    以上是對stack的部分方法的介紹,由于在操作數據存儲的同時,會考慮到線程的安全性。

   進程作為操作系統執行程序的基本單位,擁有應用程序的資源,進程包含線程,進程的資源被線程共享,線程不擁有資源。線程分為前臺線程和后臺線程,通過Thread類新建線程默認為前臺線程。當所有前臺線程關閉時,所有的后臺線程也會被直接終止,不會拋出異常。

    接下來看一下ReaderWriterLockSlim類:

  /// <summary> /// 表示用于管理資源訪問的鎖定狀態,可實現多線程讀取或進行獨占式寫入訪問。 /// </summary> [__DynamicallyInvokable] [HostProtection(SecurityAction.LinkDemand, ExternalThreading = true, Synchronization = true)] [HostProtection(SecurityAction.LinkDemand, MayLeakOnAbort = true)] public class ReaderWriterLockSlim : IDisposable {  /// <summary>  /// 使用默認屬性值初始化 <see cref="T:System.Threading.ReaderWriterLockSlim"/> 類的新實例。  /// </summary>  [__DynamicallyInvokable]  public ReaderWriterLockSlim();  /// <summary>  /// 在指定鎖定遞歸策略的情況下初始化 <see cref="T:System.Threading.ReaderWriterLockSlim"/> 類的新實例。  /// </summary>  /// <param name="recursionPolicy">枚舉值之一,用于指定鎖定遞歸策略。</param>  [__DynamicallyInvokable]  public ReaderWriterLockSlim(LockRecursionPolicy recursionPolicy);  /// <summary>  /// 嘗試進入讀取模式鎖定狀態。  /// </summary>  /// <exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入讀取的模式。- 或 -當它已經包含寫入鎖時,當前線程可能不會獲取讀的鎖定。- 或 -遞歸數將超出該計數器的容量。此限制是很大的應用程序應永遠不會遇到它。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public void EnterReadLock();  /// <summary>  /// 嘗試進入讀取模式鎖定狀態,可以選擇超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入讀取模式,則為 true;否則為 false。  /// </returns>  /// <param name="timeout">等待的間隔;或為 -1 毫秒,表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="timeout"/> 為負數,但它不等于-1 毫秒為單位),這是唯一允許的值為負。- 或 -值 <paramref name="timeout"/> 大于 <see cref="F:System.Int32.MaxValue"/> 毫秒為單位)。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterReadLock(TimeSpan timeout);  /// <summary>  /// 嘗試進入讀取模式鎖定狀態,可以選擇整數超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入讀取模式,則為 true;否則為 false。  /// </returns>  /// <param name="millisecondsTimeout">等待的毫秒數,或為 -1 (<see cref="F:System.Threading.Timeout.Infinite"/>),表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="millisecondsTimeout"/> 為負數,但它不是等于 <see cref="F:System.Threading.Timeout.Infinite"/> (-1),這是唯一允許的值為負。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterReadLock(int millisecondsTimeout);  /// <summary>  /// 嘗試進入寫入模式鎖定狀態。  /// </summary>  /// <exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已在任何模式下進入該鎖。- 或 -當前線程已進入讀取的模式,因此嘗試進入鎖定狀態寫模式,則會創建導致死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public void EnterWriteLock();  /// <summary>  /// 嘗試進入寫入模式鎖定狀態,可以選擇超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入寫入模式,則為 true;否則為 false。  /// </returns>  /// <param name="timeout">等待的間隔;或為 -1 毫秒,表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -當前線程最初在讀取模式中,輸入該鎖,因此嘗試進入寫入模式會創建導致死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="timeout"/> 為負數,但它不等于-1 毫秒為單位),這是唯一允許的值為負。- 或 -值 <paramref name="timeout"/> 大于 <see cref="F:System.Int32.MaxValue"/> 毫秒為單位)。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterWriteLock(TimeSpan timeout);  /// <summary>  /// 嘗試進入寫入模式鎖定狀態,可以選擇超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入寫入模式,則為 true;否則為 false。  /// </returns>  /// <param name="millisecondsTimeout">等待的毫秒數,或為 -1 (<see cref="F:System.Threading.Timeout.Infinite"/>),表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -當前線程最初在讀取模式中,輸入該鎖,因此嘗試進入寫入模式會創建導致死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="millisecondsTimeout"/> 為負數,但它不是等于 <see cref="F:System.Threading.Timeout.Infinite"/> (-1),這是唯一允許的值為負。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterWriteLock(int millisecondsTimeout);  /// <summary>  /// 嘗試進入可升級模式鎖定狀態。  /// </summary>  /// <exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已在任何模式下進入該鎖。- 或 -當前線程已進入讀取的模式,因此嘗試進入可升級模式將有死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public void EnterUpgradeableReadLock();  /// <summary>  /// 嘗試進入可升級模式鎖定狀態,可以選擇超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入可升級模式,則為 true;否則為 false。  /// </returns>  /// <param name="timeout">等待的間隔;或為 -1 毫秒,表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -當前線程最初在讀取模式中,輸入該鎖,因此嘗試進入可升級模式會創建導致死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="timeout"/> 為負數,但它不等于-1 毫秒為單位),這是唯一允許的值為負。- 或 -值 <paramref name="timeout"/> 大于 <see cref="F:System.Int32.MaxValue"/> 毫秒為單位)。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterUpgradeableReadLock(TimeSpan timeout);  /// <summary>  /// 嘗試進入可升級模式鎖定狀態,可以選擇超時時間。  /// </summary>  ///   /// <returns>  /// 如果調用線程已進入可升級模式,則為 true;否則為 false。  /// </returns>  /// <param name="millisecondsTimeout">等待的毫秒數,或為 -1 (<see cref="F:System.Threading.Timeout.Infinite"/>),表示無限期等待。</param><exception cref="T:System.Threading.LockRecursionException"><see cref="P:System.Threading.ReaderWriterLockSlim.RecursionPolicy"/> 屬性是 <see cref="F:System.Threading.LockRecursionPolicy.NoRecursion"/> 和當前的線程已進入該鎖。- 或 -當前線程最初在讀取模式中,輸入該鎖,因此嘗試進入可升級模式會創建導致死鎖的可能性。- 或 -遞歸數將超出該計數器的容量。限制為應用程序應永遠不會遇到它太大。</exception><exception cref="T:System.ArgumentOutOfRangeException">值 <paramref name="millisecondsTimeout"/> 為負數,但它不是等于 <see cref="F:System.Threading.Timeout.Infinite"/> (-1),這是唯一允許的值為負。</exception><exception cref="T:System.ObjectDisposedException"><see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象已被釋放。</exception>  [__DynamicallyInvokable]  public bool TryEnterUpgradeableReadLock(int millisecondsTimeout);  /// <summary>  /// 減少讀取模式的遞歸計數,并在生成的計數為 0(零)時退出讀取模式。  /// </summary>  /// <exception cref="T:System.Threading.SynchronizationLockException">在讀取模式中,當前線程不已進入該鎖。</exception>  [__DynamicallyInvokable]  public void ExitReadLock();  /// <summary>  /// 減少寫入模式的遞歸計數,并在生成的計數為 0(零)時退出寫入模式。  /// </summary>  /// <exception cref="T:System.Threading.SynchronizationLockException">當前線程不已進入寫入模式的鎖定。</exception>  [__DynamicallyInvokable]  public void ExitWriteLock();  /// <summary>  /// 減少可升級模式的遞歸計數,并在生成的計數為 0(零)時退出可升級模式。  /// </summary>  /// <exception cref="T:System.Threading.SynchronizationLockException">當前線程不已進入可升級模式的鎖定。</exception>  [__DynamicallyInvokable]  public void ExitUpgradeableReadLock();  /// <summary>  /// 釋放 <see cref="T:System.Threading.ReaderWriterLockSlim"/> 類的當前實例所使用的所有資源。  /// </summary>  /// <exception cref="T:System.Threading.SynchronizationLockException"><see cref="P:System.Threading.ReaderWriterLockSlim.WaitingReadCount"/> 是大于零。- 或 -<see cref="P:System.Threading.ReaderWriterLockSlim.WaitingUpgradeCount"/> 是大于零。- 或 -<see cref="P:System.Threading.ReaderWriterLockSlim.WaitingWriteCount"/> 是大于零。</exception><filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public void Dispose();  /// <summary>  /// 獲取一個值,該值指示當前線程是否已進入讀取模式的鎖定狀態。  /// </summary>  ///   /// <returns>  /// 如果當前線程已進入讀取模式,則為 true;否則為 false。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public bool IsReadLockHeld { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取一個值,該值指示當前線程是否已進入可升級模式的鎖定狀態。  /// </summary>  ///   /// <returns>  /// 如果當前線程已進入可升級模式,則為 true;否則為 false。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public bool IsUpgradeableReadLockHeld { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取一個值,該值指示當前線程是否已進入寫入模式的鎖定狀態。  /// </summary>  ///   /// <returns>  /// 如果當前線程已進入寫入模式,則為 true;否則為 false。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public bool IsWriteLockHeld { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取一個值,該值指示當前 <see cref="T:System.Threading.ReaderWriterLockSlim"/> 對象的遞歸策略。  /// </summary>  ///   /// <returns>  /// 枚舉值之一,用于指定鎖定遞歸策略。  /// </returns>  [__DynamicallyInvokable]  public LockRecursionPolicy RecursionPolicy { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取已進入讀取模式鎖定狀態的獨有線程的總數。  /// </summary>  ///   /// <returns>  /// 已進入讀取模式鎖定狀態的獨有線程的數量。  /// </returns>  [__DynamicallyInvokable]  public int CurrentReadCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取當前線程進入讀取模式鎖定狀態的次數,用于指示遞歸。  /// </summary>  ///   /// <returns>  /// 如果當前線程未進入讀取模式,則為 0(零);如果線程已進入讀取模式但卻不是以遞歸方式進入的,則為 1;或者如果線程已經以遞歸方式進入鎖定模式 n - 1 次,則為 n。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int RecursiveReadCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取當前線程進入可升級模式鎖定狀態的次數,用于指示遞歸。  /// </summary>  ///   /// <returns>  /// 如果當前線程沒有進入可升級模式,則為 0;如果線程已進入可升級模式卻不是以遞歸方式進入的,則為 1;或者如果線程已經以遞歸方式進入可升級模式 n - 1 次,則為 n。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int RecursiveUpgradeCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取當前線程進入寫入模式鎖定狀態的次數,用于指示遞歸。  /// </summary>  ///   /// <returns>  /// 如果當前線程沒有進入寫入模式,則為 0;如果線程已進入寫入模式卻不是以遞歸方式進入的,則為 1;或者如果線程已經以遞歸方式進入寫入模式 n - 1 次,則為 n。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int RecursiveWriteCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取等待進入讀取模式鎖定狀態的線程總數。  /// </summary>  ///   /// <returns>  /// 等待進入讀取模式的線程總數。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int WaitingReadCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取等待進入可升級模式鎖定狀態的線程總數。  /// </summary>  ///   /// <returns>  /// 等待進入可升級模式的線程總數。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int WaitingUpgradeCount { [__DynamicallyInvokable] get; }  /// <summary>  /// 獲取等待進入寫入模式鎖定狀態的線程總數。  /// </summary>  ///   /// <returns>  /// 等待進入寫入模式的線程總數。  /// </returns>  /// <filterpriority>2</filterpriority>  [__DynamicallyInvokable]  public int WaitingWriteCount { [__DynamicallyInvokable] get; } }

以上是對Stack和線程的相關知識的淺述,現在介紹一下線程安全的Stack:

 /// <summary>  /// 表示對象的后進先出線程安全集合(棧結構)  /// </summary>  /// <typeparam name="T"></typeparam>  public class TStack<T> : IEnumerable<T>, ICollection  {    /// <summary>    /// 內部堆棧    /// </summary>    private readonly Stack<T> _mStack;    /// <summary>    /// 鎖訪問堆棧(用于管理資源訪問的鎖定狀態,可實現多線程讀取或進行獨占式寫入訪問。)    /// </summary>    private readonly ReaderWriterLockSlim _lockStack = new ReaderWriterLockSlim();    /// <summary>    /// 僅用于SyncRoot屬性    /// </summary>    private readonly object _objSyncRoot = new object();    // Variables    /// <summary>    /// 初始化一個新的實例 <see cref="TStack{T}"/> class.    /// </summary>    public TStack()    {      _mStack = new Stack<T>();    }    /// <summary>    /// 初始化一個新的實例 <see cref="TStack{T}"/> class.    /// </summary>    /// <param name="col">    /// 開始集合    /// </param>    public TStack(IEnumerable<T> col)    {      _mStack = new Stack<T>(col);    }    // Init    /// <summary>    /// 獲取枚舉器    /// </summary>    public IEnumerator<T> GetEnumerator()    {      Stack<T> localStack = null;      // 初始化枚舉器      _lockStack.PerformUsingReadLock(() =>      {        // 創建一個m_tlist副本        localStack = new Stack<T>(_mStack);      });      // 獲取枚舉器      foreach (T item in localStack)        yield return item;    }    /// <summary>    /// 獲取枚舉器    /// </summary>    IEnumerator IEnumerable.GetEnumerator()    {      Stack<T> localStack = null;      // 初始化枚舉器      _lockStack.PerformUsingReadLock(() =>      {        // 創建一個m_TList的副本        localStack = new Stack<T>(_mStack);      });      // 獲取枚舉器      foreach (T item in localStack)        yield return item;    }    /// <summary>    /// 復制到一個數組    /// </summary>    /// <param name="array"></param>    /// <param name="index"></param>    public void CopyTo(Array array, int index)    {      _lockStack.PerformUsingReadLock(() => _mStack.ToArray().CopyTo(array, index));    }    /// <summary>    ///堆棧中的項目數    /// </summary>    public int Count    {      get      {        return _lockStack.PerformUsingReadLock(() => _mStack.Count);      }    }    /// <summary>    /// 總為真    /// </summary>    public bool IsSynchronized    {      get { return true; }    }    /// <summary>    ///同步根    /// </summary>    public object SyncRoot    {      get { return _objSyncRoot; }    }    /// <summary>    ///清除集合    /// </summary>    public void Clear()    {      _lockStack.PerformUsingWriteLock(() => _mStack.Clear());    }    // Clear    /// <summary>    ///如果項目在堆棧中,則為true    /// </summary>    /// <param name="item"></param>    /// <returns></returns>    public bool Contains(T item)    {      return _lockStack.PerformUsingReadLock(() => _mStack.Contains(item));    }    // 包含    /// <summary>    /// 返回堆棧中的頂部項,而不從堆棧中刪除它    /// </summary>    /// <returns></returns>    public T Peek()    {      return _lockStack.PerformUsingReadLock(() => _mStack.Peek());    }    // Peek    /// <summary>    ///刪除并返回堆棧中的頂部項目    /// </summary>    /// <returns></returns>    public T Pop()    {      return _lockStack.PerformUsingWriteLock(() => _mStack.Pop());    }    // Pop    /// <summary>    /// 將一個項目插入堆棧    /// </summary>    /// <param name="item"></param>    public void Push(T item)    {      _lockStack.PerformUsingWriteLock(() => _mStack.Push(item));    }    // Push    /// <summary>    ///將堆棧轉換為數組    /// </summary>    /// <returns></returns>    public T[] ToArray()    {      return _lockStack.PerformUsingReadLock(() => _mStack.ToArray());    }    // ToArray    /// <summary>    /// 將容量設置為堆棧中實際的元素數量    /// </summary>    public void TrimExcess()    {      _lockStack.PerformUsingWriteLock(() => _mStack.TrimExcess());    }  }

    以上的操作方法繼承了IEnumerable<T>, ICollection兩個接口。有興趣的,可以對IEnumerable<T>, ICollection兩個接口進行細致的了解。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久男人的天堂| 亚洲娇小xxxx欧美娇小| 亚洲天堂成人在线视频| 久久韩国免费视频| 日韩毛片在线观看| 成人网址在线观看| 国产成人精品优优av| 欧美性生交xxxxxdddd| 成人性教育视频在线观看| …久久精品99久久香蕉国产| 国产欧美日韩精品在线观看| 亚洲色图18p| 亚洲精品v欧美精品v日韩精品| 久久久久久高潮国产精品视| 亚洲电影在线观看| 成人在线观看视频网站| 色偷偷噜噜噜亚洲男人的天堂| 91av视频在线观看| 日韩在线欧美在线| 伊人av综合网| 最近2019中文字幕大全第二页| 欧美视频在线观看 亚洲欧| 91免费看片在线| 97久久精品人人澡人人爽缅北| 中文字幕欧美在线| 日韩精品高清在线观看| 51色欧美片视频在线观看| 亚洲电影免费观看高清完整版在线观看| 国产免费一区视频观看免费| 国产精品久久久久久久久久99| 国产亚洲激情视频在线| 欧美裸体xxxxx| 日本精品久久久久影院| 国产精品第8页| 欧美激情视频播放| 亚洲美女又黄又爽在线观看| 欧美中在线观看| 亚洲开心激情网| 国产精品日韩专区| 北条麻妃一区二区三区中文字幕| 欧美国产视频一区二区| 亚洲男人av电影| 57pao成人国产永久免费| 欧美精品videos| 91精品免费久久久久久久久| 精品久久久久国产| 亚洲天堂2020| 国产精品视频永久免费播放| 久久久久久久激情视频| 日本在线观看天堂男亚洲| 91精品国产色综合久久不卡98| 午夜精品免费视频| 永久免费看mv网站入口亚洲| 亚洲自拍偷拍在线| 国内精品小视频在线观看| 奇门遁甲1982国语版免费观看高清| 欧美在线视频免费观看| 国产精品十八以下禁看| 97久久超碰福利国产精品…| 亚洲国产日韩欧美在线动漫| 亚洲精品不卡在线| 久久久精品免费视频| 92版电视剧仙鹤神针在线观看| 成人两性免费视频| 欧美日韩在线视频观看| 久久久久亚洲精品国产| 欧美天堂在线观看| 精品国模在线视频| 成人免费视频网| 在线观看久久久久久| 欧美制服第一页| 91在线|亚洲| 中文字幕一精品亚洲无线一区| 国产精品福利在线观看网址| 国产日韩欧美综合| 欧美激情在线有限公司| 日韩在线观看免费高清| 伊人男人综合视频网| 欧美做受高潮电影o| 亚洲精品国产精品乱码不99按摩| 成人激情在线播放| 亚洲电影免费观看高清完整版在线观看| 精品女同一区二区三区在线播放| 国产精品成人免费视频| 国产精品视频1区| 国产精品久久久久久久久久久久久久| 国产精品爽爽爽爽爽爽在线观看| 免费av在线一区| 欧美一区深夜视频| 26uuu日韩精品一区二区| 久久久久久久国产精品视频| 国产视频精品va久久久久久| 日本乱人伦a精品| 亚洲第一精品久久忘忧草社区| 5252色成人免费视频| 亚洲天堂网站在线观看视频| 国产精品手机播放| 精品亚洲一区二区三区| 欧美重口另类videos人妖| 国产精品日日摸夜夜添夜夜av| 伊人伊成久久人综合网站| 91亚洲精品在线| 国产成人福利夜色影视| 欧美日在线观看| 亚洲精品www| 欧美综合第一页| 成人a免费视频| 伊人久久免费视频| 91精品在线一区| 日韩av不卡电影| 综合久久五月天| 4438全国亚洲精品在线观看视频| 国产精品久久久久久中文字| 不卡av电影在线观看| 欧美激情视频一区| 91久久国产精品| 欧美日韩免费观看中文| 精品欧美一区二区三区| 日韩精品中文字幕在线| 精品久久久91| 精品亚洲一区二区| 韩国三级日本三级少妇99| 国产精品情侣自拍| 亚洲精品资源在线| 亚洲第一精品夜夜躁人人爽| www.日韩欧美| 日韩欧美在线观看视频| 成人羞羞国产免费| 亚洲福利在线看| 国产精品国内视频| 欧美xxxx做受欧美.88| 久久亚洲成人精品| 久久久女人电视剧免费播放下载| 久久久噜噜噜久久久| 色妞色视频一区二区三区四区| 国产精品福利在线观看网址| 91免费国产视频| 俺去亚洲欧洲欧美日韩| 欧美激情性做爰免费视频| 精品国内产的精品视频在线观看| 亚洲小视频在线观看| 欧美成人中文字幕在线| 国产精品盗摄久久久| 日韩精品视频中文在线观看| 久久影视电视剧免费网站| 97av在线播放| 91精品久久久久久久| 欧洲精品在线视频| 日韩视频在线一区| 久久精品国产亚洲一区二区| 国产精品电影在线观看| 国产精品精品国产| 国产精品日韩一区| 91网在线免费观看| 久久国产精品视频| 亚洲一区二区三区xxx视频| 欧美大尺度激情区在线播放| 色综合久久天天综线观看| 中文字幕亚洲二区| 欧美精品成人在线| 中文字幕在线视频日韩| 亚洲深夜福利视频| 久久免费少妇高潮久久精品99| 91禁国产网站|