Ana içeriğe atla

C# Interface Kullanımı




C#'da bir interface, nesne yönelimli programlamada (OOP) bir sözleşme (contract) olarak işlev gören bir yapıdır. Bir interface, bir sınıfın sahip olması gereken yöntemler, özellikler, olaylar veya dizinleyiciler gibi üye tanımlamalarını belirtir, ancak bu üyeler için bir uygulama sağlamaz. Bu nedenle, bir interface, sadece ne yapılması gerektiğini belirtir ama nasıl yapılacağını belirlemez.

Interface'in Avantajları ve Kullanım Nedenleri

  1. Bağımlılığı Azaltma (Loosely Coupling): Interface'ler, kodun daha bağımsız hale gelmesine yardımcı olur. Bir sınıfın başka bir sınıfa sıkı sıkıya bağlı olmasını önleyerek, değişikliklerin diğer sınıfları etkilemesini en aza indirir.

  2. Çoklu Kalıtım Desteği: C#'da sınıflar yalnızca bir sınıftan türeyebilir, ancak birden fazla interface'den kalıtılabilir. Bu, çoklu kalıtım ihtiyaçlarını karşılamak için önemli bir özelliktir.

  3. Kodun Test Edilebilirliğini Artırma: Interface'ler kullanarak nesneleri soyutlayabilir ve testlerde mock nesneler kullanarak bağımsız birim testleri yapılabilir.

  4. Polimorfizm (Çok Biçimlilik) Sağlama: Interface'ler, bir nesnenin farklı formlarda kullanılabilmesini sağlar. Bir interface türündeki bir nesne, farklı sınıflar tarafından uygulanabilir; bu da esnek ve genişletilebilir bir yapı sunar.

Yorumlar

Bu blogdaki popüler yayınlar

FOREGIN KEY ve INNER JOIN ile ilişkili tablo oluşturma Örneği

--1)DataBase oluşturma Sorgusu --CREATE DATABASE Join_Alistirma; --GO --USE Join_Alistirma; --GO --2)musteri Tablosu oluşturma --CREATE TABLE musteri ( --    musteri_ID INT IDENTITY(1,1) PRIMARY KEY, --    adi_soyadi NVARCHAR(100) NOT NULL, --    telefon NVARCHAR(20) NOT NULL --); ---3)araclar Tablosunu Oluştur (FOREIGN KEY ile) --CREATE TABLE araclar ( --    id INT IDENTITY(1,1) PRIMARY KEY, --    musteri_ID INT NOT NULL, --    plaka NVARCHAR(20) NOT NULL, --    marka NVARCHAR(50), --    model NVARCHAR(50), --    yil INT, --    FOREIGN KEY (musteri_ID) REFERENCES musteri(musteri_ID) --); ----------------------------------------------------------------------------- ----NOT  --musteri_ID → musteri tablosuyla bağlantılı olacak. --plaka, marka, model, yil alanları araç bilgilerini tutacak. ----------------------------------------------------------------------------- ---4)Tablolara muste...

Private Void Metod

 namespace Metotlar {     public partial class Form1 : Form     {         public Form1()         {             InitializeComponent();         }         //Parametre Almayan Değer Döndürmeyen Metot         //Değer döndürmeyen metot tanımlarken Başa Void yazılır         //Tekrar tekrar aynı kod parçasını yazmaya gerek kalmaz Metot adını istediğinde çağarabilirsin         //void : private void olan metot başka yerden erişelemez         //public void olanlar ise erişime açık (dışarıdan görülebilen) anlamına gelir         //Örnek : MesayYaz Metotu: Çağrıldığı yerde ekrana bir mesaj veren metot yazalım         void MesajYaz()          {             MessageBox.Show("Merhaba Ben Parametresiz...

İD ye göre işlemler C# ve Class örnekleri ile Birlikte

***************************************************************************** ✅ DbHelper.cs adında bir sınıf ile Insert , Update , Delete , GetId , SelectAll işlemlerini kolayca yapabilirsiniz. ✅ SCOPE_IDENTITY() kullanarak son eklenen kaydın ID’sini çekme örneği var. ✅ Bu ID’yi Label veya TextBox ’a yazdırabilir, Update veya Delete için tekrar kullanabilirsiniz. ✅ DataGridView ile tüm verileri listeleme örneği de dahil. *****************************************************************************  // ✅ DbHelper.cs using System; using System.Collections.Generic; using System.Data; using System.Data.SqlClient; public static class DbHelper {     private static string connectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=YourDatabase;Integrated Security=True";     public static object InsertAndGetId(string query, Dictionary<string, string> parameters)     {         using (SqlConnection connection = new SqlConne...