C# TA INTERFACE VE MİRAS ÖRNEĞİ

Bu Yazımda Sizlere Daha Önce Bahsettiğim C# taki İnterface kavramını biraz daha irdeleyebilmek için Özenle Hazırladığım Çok Güzel Bir Örnekle anlatıp yazımı bitireceğim.Bildiğiniz gibi İnterface ler Bir Şablon yapıdır Abstract class lara bir çok yönden benzeselerde Bir kaç istisnalarda yok değil en önemliside İnterface lerde Metotlar ve değişkenler Sadece Tanımlanır Ancak Asla İmplemente Edilmezler Bu yönden Abstract class lardan Ayrılırlar ancak 2 yöntemde de İnstance veyahut Nesne Oluşturaramaysa ortak özellik olarak karşımıza çıkmakta ve bu iki yöntemde Belekte sanal alanda tutulup Runtime aşamsında Yer Tahsis edilirler.Şimdi Örneğimize Geçip Örnek üzerinden Ayrıntılı bir şekilde Örneğimizi açıklayalım umarım anlaşılır tabi anlaşılması için öncellikle aşağıdaki kodu Visual Studio 2008 derleyicisine konulup Run Edilmesi gerekiyor ardından sonuçları gözlemleyerek bu konuyu iyice irdeleyebileceğinizi umuyorum.Anlaşılmayan noktaları sorabilirsiniz.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication2
{

// İlk Arayüz Tanımlanıyor
public interface IArayuz
{

// Metotlar Ve Değişkenler Görüldüğü Gibi sadece tanımlanıyor implemente edilmiyor…
string ParametreGetir();
void Kaydet();

// Burdada Bu değişkene Ait Get ve Set Metotlarının olduğu bildiriliyor Aslında Default olarakta zaten var bu özellikler
int ParametreSayısı
{
get;
set;
}
string ParametreAdi
{
get;
set;
}
}

// İkinci Arayüz Tanımlanıyor
public interface IParametre
{
string ParametreGetir();
void Kaydet();

int ParametreSayısı
{
get;
set;
}
string ParametreAdi
{
get;
set;
}
}

// Burda IArayüz İnterface ini miras olarak bilgiler Class ına veriyoruz tüm metot ve değişkenler Artık bilgiler

//Classına geçti burda ister  o fonksiyonları implemente ederiz istersekte yeni fonksiyonlarda tanımlayabiliriz..

public class Bilgiler : IArayuz
{
public string ParametreGetir()
{
Console.WriteLine(“Parametreler Hazır…”);
return “OK”;
}

// IArayüz İnterfaceinde Tanımladığımız Kaydet Metotunu burda implemente Ettik

public void Kaydet()
{
Console.WriteLine(“IArayuz.Kaydet Arayüzü Koşuyor…”);
}

public int _deneme;
private int _ParametreSayısı;
public int ParametreSayısı
{
get;
set;
}
private string _ParametreAdi;
public string ParametreAdi
{
get { return _ParametreAdi; }
set { _ParametreAdi = value; }
}
}

//burda da IArayüz ve IParametre interface lerini Bilgigöster classına Miras Olarak verdik bildiğiniz gibi normalde

//C# ta bir class a sadece bir class ı aynı anda Miras olarak verebiliriz daha fazla yapmak istiyorsak ya Abstract

//Class ları kullanacaz yada interface leri devreye koyacaz…

public class BilgiGoster : IArayuz, IParametre
{
private int  _ParametreSayısı;
public int ParametreSayısı
{
get { return _ParametreSayısı; }
set { _ParametreSayısı = value; }
}
private string _ParametreAdi;
public string ParametreAdi
{
get { return _ParametreAdi; }
set { _ParametreAdi = value; }
}
public string ParametreGetir()
{
Console.WriteLine(“Parametreler Hazır…”);
return “OK”;
}

// IArayüz İnterfaceinde Tanımladığımız Kaydet Metotunu burda implemente Ettik

void IArayuz.Kaydet()
{
Console.WriteLine(“IArayuz.Kaydet Arayüzü Koşuyor…”);
}

// IParametre İnterfaceinde Tanımladığımız Kaydet Metotunu burda implemente Ettik

void IParametre.Kaydet()
{
Console.WriteLine(“IParametre.Kaydet Arayüzü Koşuyor…”);
}
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine(“\t\tMEHMET SALİH DEVECİ-15.08.2010\n”);

//burda bilgi göster classı için nesne tanımlıyoruz
BilgiGoster bg = new BilgiGoster();
IArayuz a = (IArayuz)bg;  //bunun yerine IArayuz a=new BilgiGoster() de yapabilirdik
IParametre p = (IParametre)bg; //burdaysa Bilgigoster Classını Iparametre arayüzüne Dönüştürüyoruz
a.Kaydet(); //Burda IArayuzun Kaydet Metotu çağrılır
p.Kaydet();//Burda Iparametre nin Kaydet Metotu çağrılır
Console.ReadLine();
}
}
}

Şimdi Kodun Çıktısını görelim:

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 [email protected] 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

About Mehmet Salih Deveci

I am Founder of SysDBASoft IT and 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 [email protected].-                                                                                                                                                                                                                                                 -Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS ve linux Danışmanlık ve Eğitim için  [email protected] a mail atabilirsiniz.

4 comments

  1. Cok güzel anlasılır bir örnek…

  2. Teşekkür Ederim Yavuz Bey Beğendiğinize Sevindim!!!

  3. cok önemli bir konu vizyonumuzu acıyorsun !!!

  4. Ne Demek Asıl siz bizim vizyonumuzu açıyorsunuz yavuz bey!!!

Leave a Reply

Your email address will not be published. Required fields are marked *