ConcurrentQueue represents a thread-safe first in-first out (FIFO) collection. : ConcurrentQueue « Collections Data Structure « C# / C Sharp






ConcurrentQueue represents a thread-safe first in-first out (FIFO) collection.

 

using System;
using System.Collections.Concurrent;
using System.Threading;
using System.Threading.Tasks;

class MainClass
{
        static void Main ()
        {
            ConcurrentQueue<int> cq = new ConcurrentQueue<int>();
            for (int i = 0; i < 10000; i++) cq.Enqueue(i);
            int result;
            if (!cq.TryPeek(out result))
            {
                Console.WriteLine("CQ: TryPeek failed when it should have succeeded");
            }
            else if (result != 0)
            {
                Console.WriteLine("CQ: Expected TryPeek result of 0, got {0}", result);
            }
            int outerSum = 0;
            Action action = () =>
            {
                int localValue;
                int localSum = 0;
                while (cq.TryDequeue(out localValue)) localSum++;
                Interlocked.Add(ref outerSum, localSum);
            };
            Parallel.Invoke(action, action, action, action);
            Console.WriteLine( outerSum);
        }
}

   
  








Related examples in the same category