C# TA STACK (YIĞIN) VERİYAPISI

Merhaba Değerli Arkadaşlar bugünkü yazımda sizlere programcılığın önemli yapıtaşlarından olan veri yapılarına değinecek ve bununla birliktede Stack (Yığın) veri yapısını yaptığım bir uygulamayla beraber anlatacağım.

Veri Yapıları;Bilgilerin effektif bir şekilde saklanması ve aynı şekilde işlenmesi açısından oluşturulan yapılardır. En basit anlamda bir value nun Type ı aynı zamanda en basitinden o value için bir veri yapısıdır.Bilinen Veri yapıları Stack (Yığın),Queue (Kuyruk),Bağlı listeler (Linked lists) ve Ağaç (Tree) dir.

Bunların bir çoğu birbirine benzemesine rağmen temel olarak bazı farklılıklarıda barındırmaktadır. Örneğin,Stack veri yapısına eklenen veriler içerisinden son eklenen veri aynı zamanda Stackdan eğer çekilecekse ilk veridir.Ancak Queue (Kuyruk) veri yapısı ise son eklenen eleman son,ilk eklenen elemansa veriler çekilirken ilk çekilecek elemandır.Bunlara benzer yapısal farklar oluşmasına rağmen veri yapılarının temel yapıları aynı olmaktadır.
Şimdi biz asıl konumuza dönelim ve Stack (Yığın) veri yapısına değindikten sonra bir uygulama yapalım.

Veri yapılarının bilinen önemli konularından biriside hiç kuşku yok ki Stack (Yığın) Konusudur.Yığın veri yapısı üst üste koyulan tabaklar mantığıyla çalışır ilk çektiğimiz son koyduğumuz tabaktır aslında bundan da anlaşılacağı üzere Stack son giren ilk çıkar yani LIFO ( Last in First Out ) mantığıyla çalışır.Burda herbir eleman için bir Node (düğüm) oluşturarak Class yapısının içinde kullandım ve her elemanı önce ittim (PUSH) Yığına sonra da çektim (POP) çektim Stacktan.Şimdide .Net Framework le gelen Stack sınıfına bakalım..Net kütüphanesinde ki collections kütüphanesinde bulunan Stack sınıfı aynı zamanda bir çok metot veya Java daki Adıyla Yordam barındırmaktadır.Bunlardan bazıları ve önemli olanları şunlardır:

  • Push
  • Pop
  • Clear
  • Count
  • CopyTo
  • Clone

Bu metotlardan bir çoğunu önceki yazımda da belirttiğim gibi Sınıfın üstüne gelip sağ tıkladıktan sonra gelen menuden Go To Definition sekmesine tıkladıktan sonra gelen menuden tanımlarına ve aldıkları parametreleri bulabilirsiniz şimdide geçelim yaptığımız uygulamaya aşağıda uygulamamızın kodları bulunmaktadır.

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
Stack x = new Stack();
for (int i = 0; i < 10; i++)
x.Push(i);
Console.WriteLine(“MEHMET SALİH DEVECİ…13.07.2010″);
Console.WriteLine(“STAGAžİTİLEN ELEMANLAR\n”);
foreach (int h in x)
Console.Write(h+”   “);
Console.WriteLine(“\n\n”);
x.Pop();
foreach (int h in x)
Console.WriteLine(h);
Console.ReadLine();
}
}
}

Uygulamayı Visual Studio 2008 de derleyince karşımıza şu çıktı gelicektir: 

 

Oracle Exadata SQL Server Goldengate Weblogic EBS ve Linux konusunda aşağıdaki konularda 7×24 Uzman Danışmanlara yada Eğitimlere mi
İhtiyacınız var mehmet.deveci@gridgroup.com.tr adresine mail atarak Bizimle iletişime geçebilirsiniz.

– Oracle Veritabanı Danışmanlığı
– Oracle Veritabanı Bakım ve Destek
– Exadata Danışmanlığı
– Exadata Bakım ve Destek
– SQL Server Veritabanı Danışmanlığı
– SQL Server Veritabanı Bakım ve Destek
– Goldengate Danışmanlığı
– Goldengate Bakım ve Destek
– Linux Danışmanlığı
– Linux Bakım ve Destek
– Oracle EBS Danışmanlığı
– Oracle EBS Bakım ve Destek
– Weblogic Danışmanlığı
– Weblogic Bakım ve Destek
– Oracle Veritabanı Eğitimleri
– Oracle VM Server Danışmanlığı
– Oracle VM Server Bakım ve Destek
– Oracle EPPM Danışmanlığı
– Oracle EPPM Bakım ve Destek
– Oracle Primavera Danışmanlığı
– Oracle Primavera Bakım ve Destek
– Oracle Eğitimleri
– SQL Server Eğitimleri
– Goldengate Eğitimleri
– Exadata Eğitimleri
– Linux Eğitimleri
– Oracle EBS Eğitimleri
– Oracle VM Server Eğitimleri
– Weblogic Eğitimleri
– Oracle EPPM Eğitimleri
– Oracle Primavera Eğitimleri

Mehmet Salih Deveci

I am Founder of IT Tutorial and Certified Expert about Oracle & SQL Server database, Goldengate, Exadata Machine, Oracle Database Appliance administrator with 10+years experience. I have OCA, OCP, OCE RAC Expert Certificates I have worked 100+ Banking, Insurance, Finance, Telco and etc. clients as a Consultant, Insource or Outsource. I have done 200+ Operations in this clients such as Exadata Installation & PoC & Migration & Upgrade, Oracle & SQL Server Database Upgrade, Oracle RAC Installation, SQL Server AlwaysOn Installation, Database Migration, Disaster Recovery, Backup Restore, Performance Tuning, Periodic Healthchecks. I have done 2000+ Table replication with Goldengate or SQL Server Replication tool for DWH Databases in many clients. If you need Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS Consultancy and Training you can send my email adress mehmetsalih.deveci@outlook.com. -                                                                                                                                                                                                                                                 - Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS ve linux Danışmanlık ve Eğitim için  mehmetsalih.deveci@outlook.com a mail atabilirsiniz.