Queue.Clone() Method in C# (original) (raw)
Last Updated : 15 Feb, 2019
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 just the shallow copy of the Queue.
Example 1: Let's see an example without using a Clone() method and directly copying a Queue using assignment operator '='. In the below code, we can see even if we Dequeue() elements from myQueue2, contents of myQueue is also changed. This is because '=' just assigns the reference of myQueue to myQueue2 and does not create any new Queue. But Clone() creates a new Queue.
csharp `
// C# program to Copy a Queue using // the assignment operator using System; using System.Collections;
class GFG {
// Main Method
public static void Main(string[] args)
{
Queue myQueue = new Queue();
myQueue.Enqueue("Geeks");
myQueue.Enqueue("Class");
myQueue.Enqueue("Noida");
myQueue.Enqueue("UP");
// Creating a copy using the
// assignment operator.
Queue myQueue2 = myQueue;
myQueue2.Dequeue();
PrintValues(myQueue);
}
public static void PrintValues(IEnumerable myCollection)
{
// This method prints all the
// elements in the Stack.
foreach(Object obj in myCollection)
Console.WriteLine(obj);
}
}
`
Example 2: Here myQueue is unchanged.
csharp `
// C# program to illustrate the use // of Object.Clone() Method using System; using System.Collections;
class GFG {
// Main Method
public static void Main(string[] args)
{
Queue myQueue = new Queue();
myQueue.Enqueue("Geeks");
myQueue.Enqueue("Class");
myQueue.Enqueue("Noida");
myQueue.Enqueue("UP");
// Creating copy using Clone() method.
Queue myQueue2 = (Queue)myQueue.Clone();
myQueue2.Dequeue();
PrintValues(myQueue);
}
public static void PrintValues(IEnumerable myCollection)
{
// This method prints all the
// elements in the Stack.
foreach(Object obj in myCollection)
Console.WriteLine(obj);
Console.WriteLine();
}
}
`
Output:
Geeks Class Noida UP
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