This tutorial is about stacks in C#. The Stack class represents a last-in-first-out (LIFO) Stack of Objects

Don’t forget to check out our site for more free how-to videos! – our feed – join us on facebook – our group in Google+

Introduction on How to work with Stacks in C#

Stacks in C# represent a last-in-first-out (LIFO) Stack of Objects. A stack in C# will follow the push-pop operation. That is we can Push (insert) Items into Stack and Pop (retrieve) it back.

A stack in C# is implemented as a circular buffer. That is you can push the items into a stack and get it in reverse order. Stack returns the last item first. As elements are added to a Stack, the capacity is dynamically increased as required.
This is present in the namespace, System.Collections.

How to work with Stacks in C#

Step 1: Implementing Stack
The following code snippet shows the use of push and pop methods for stacks in C#:
Stack stack = new Stack();
string s = Convert.ToString(stack.Pop());
foreach (string i in stack)

Console.Write(“t” + i);

Step 2: Manipulating Stack
The pop() method pushes the last element out. Note that the stack holds objects, just like ArrayList.
The elements of the stack can be iterated using the foreach statement as well.
There are few more methods and properties that can be functionally helpful:
• Peek() — looks into the next element in the stack.
• Clear() — deletes all the elements in stack.
• Count — counts the number of elements in the stack.


Peek is similar to pop, However, peek does not remove the element from the stack while pop removes the reference entirely. Hence, if you call Pop and then Peek(), Peek() will return the next value in the stack since the reference of the first value is removed by Pop().
You can copy and search the elements of a stack, just like an ArrayList.




Please enter your comment!
Please enter your name here