How to get Synchronize access to the Queue in C# (original) (raw)
Last Updated : 18 Feb, 2019
Queue.SyncRoot Property is used to get an object which can be used to synchronize access to the Queue. Queue represents a first-in, first out collection of object. It is used when you need first-in, first-out access of items. When you add an item in the list, it is called enqueue, and when you remove an item, it is called dequeue. This class comes under System.Collections
namespace and implements ICollection, IEnumerable, and ICloneable interfaces.Important Points:
- Synchronization of an object is done so that only one thread can manipulate the data in the Queue.
- A property is a member of a class that provides a means for reading, writing and computing private data fields.
- The synchronizing code cannot directly perform on the collection, so it must perform operations on the SyncRoot of the collection in order to guarantee the proper operation of collections that are derived from other objects.
- Retrieving the value of this property is an O(1) operation.
Syntax: public virtual object SyncRoot { get; }Property Value: An object that can be used to synchronize access to the Queue.
Example 1: In this code, we are using SyncRoot to get Synchronized access to the Queue named q1, which is not a thread-safe procedure and can cause an exception. So to avoid the exception we lock the collection during the enumeration.
csharp `
// C# program to illustrate the // use of SyncRoot property of // the Queue using System; using System.Threading; using System.Collections;
namespace sync_root {
class GFG {
// Main Method
static void Main(string[] args)
{
// Declaring an Queue
Queue q1 = new Queue();
// Adding elements to Queue
q1.Enqueue(1);
q1.Enqueue(2);
q1.Enqueue(3);
q1.Enqueue(4);
q1.Enqueue(5);
// Using the SyncRoot property
lock(q1.SyncRoot)
{
// foreach loop to display
// the elements in q1
foreach(Object i in q1)
Console.WriteLine(i);
}
}
} }
`
Example 2:
csharp `
// C# program to illustrate the // use of SyncRoot property of // the Queue using System; using System.Threading; using System.Collections;
namespace sync_root {
class GFG {
// Main Method
static void Main(string[] args)
{
// Declaring an Queue
Queue q1 = new Queue();
// Adding elements to Queue
q1.Enqueue("C");
q1.Enqueue("C++");
q1.Enqueue("Java");
q1.Enqueue("C#");
q1.Enqueue("HTML");
// Using the SyncRoot property
lock(q1.SyncRoot)
{
// foreach loop to display
// the elements in q1
foreach(Object i in q1)
Console.WriteLine(i);
}
}
} }
`
Output:
C C++ Java C# HTML
Reference:
Similar Reads
- C# Queue Class In C#, the Queue class is the part of the System.Collections.Generic namespace and represent a first-in-first-out (FIFO) collection of objects. When we add an item to the list, it is called enqueue, and when we remove an item, it is called dequeue.Enqueue adds an element to the end of the Q 5 min read
- How to create a Queue in C# Queue() Constructor is used to initializes a new instance of the Queue class which will be empty, and will have the default initial capacity, and uses the default growth factor. Queue represents a first-in, first out collection of object. It is used when you need first-in, first-out access of items. 2 min read
- Queue.Count Property in C# This property is used to get the number of elements contained in the Queue. Retrieving the value of this property is an O(1) operation and it comes under the System.Collections namespace. Syntax: public virtual int Count { get; } Property Value: This property returns the number of elements contained 2 min read
- Queue.IsSynchronized Property in C# This property is used get a value which indicates whether access to the Queue is synchronized (thread safe) or not. Syntax: public virtual bool IsSynchronized { get; } Property Value: This property returns true if access to the Queue is synchronized(thread safe) otherwise, false. The default is fals 2 min read
- How to get Synchronize access to the Queue in C# Queue.SyncRoot Property is used to get an object which can be used to synchronize access to the Queue. Queue represents a first-in, first out collection of object. It is used when you need first-in, first-out access of items. When you add an item in the list, it is called enqueue, and when you remov 2 min read
- Queue.Clear Method in C# This method is used to remove the objects from the Queue. This method is an O(n) operation, where n is the total count of elements. And this method comes under System.Collections namespace. Syntax: public void Clear (); Below given are some examples to understand the implementation in a better way: 2 min read
- Queue.Clone() Method in C# This method is used to create a shallow copy of the Queue. It just creates a copy of the Queue. The copy will have a reference to a clone of the internal elements but not a reference to the original elements. Syntax: public virtual object Clone (); Return Value: The method returns an Object which is 2 min read
- Queue.Contains() Method in C# This method is used to check whether an element is in the Queue. This method performs a linear search, therefore, this method is an O(n) operation, where n is Count. And this method comes under the System.Collections namespace. Syntax: public virtual bool Contains(object obj); Here, obj is the Objec 2 min read
- Queue.CopyTo() Method in C# This method is used to copy the Queue elements to an existing one-dimensional Array, starting at the specified array index. The elements are copied to the Array in the same order in which the enumerator iterates through the Queue and this method is an O(n) operation, where n is Count. This method co 4 min read
- Queue.Dequeue Method in C# The Dequeue() method is used to returns the object at the beginning of the Queue. This method is similar to the Peek() Method. The only difference between Dequeue and Peek method is that Peek() method will not modify the Queue but Dequeue will modify. This method is an O(1) operation and comes under 2 min read