Ana içeriğe atla

Abstract Singleton Design Pattern

Geçenlerde bir projem için Singleton tasarım deseni hazırlamam gerekiyordu fakat singleton benim için tam da yeterli olmayacaktı.Çünkü proje oldukça büyük ve her an onlarca nesne örneği oluşturan ve aynı nesne örneğini farklı şekillerde oluşturan bir projeydi.Aynı nesne örneği farklı şekillerde farklı contructor lar ile oluşturulduğundan Singleton Design Pattern tek başıma işimi görmeyecekti.

Bunun üzerine işe koyuldum ve biraz araştırma birazda çalışma sonrası Factory Singleton Design Pattern kullanarak problemimi kalıcı ve etkili bir şekilde çözmüş oldum.

Factory Singleton Design Pattern ımın kodları aşağıdaki gibi :

   public static class SingletonFactory
    {
        private static readonly IDictionary<Type, object> instances;

        static DBBaseSingletonFactory()
        {
            instances = new Dictionary<Type, object>();
        }

        public static T Create<T>(params object[] args)
        {
            Type instanceType = typeof(T);

            T instance;

            if (instances.ContainsKey(instanceType))
            {
                instance = (T)instances[instanceType];
            }
            else
            {
                instance = (T)Activator.CreateInstance(instanceType, args);

                instances.Add(instanceType, instance);
            }

            return instance;

        }//End method

    }



Örnek Kullanımı aşağıdaki gibi oluyor.
Aşağıdaki örnekte veri katmanındaki DBProduct nesnesi oluşturuluyor.

 DBProduct menu = SingletonFactory.Create<DBProduct>();





Bu blogdaki popüler yayınlar

Netsis NetOpenX50 Nesnesini C# Visual Studio Üzerinde Çalıştırma

Netsis ile sipariş, ürün, fiyat, stok entegrasyonları yaparken NetOpenX apisini kullanmamız gerekiyor. Netsis kullanan bir firma ile entegrasyon geliştirmeden önce yapmamız gereken şey firmanın netopenx api lisansı alıp almadığını öğrenmeliyiz.Bunu onaylattıktan sonra Visual Studio projemize NetOpenx50 dosyasını referans olarak eklemek kalıyor. Projemize referans eklemek için öncelikle NetOpenX50.dll ini bilgisayarımıza indiriyoruz.Ardından komut sataırına girerek aşağıdaki komutu vermeliyiz. regsvr32 C:\Netsis\NetOpenX50.dll Bu işlem sonrasında NetOpenX50 dosyamızı com objesi olarak işletim sistemimize kayıt etmiş oluyoruz. Hemen ardından visual studio projemizi açarak projenin üzerinde References kısmına sağ tuş tıklayarak yeni referens ekle diyoruz.Ardından çıkan pencereden sol panelden COM objelerini seçiyoruz ve orada "NetOpenX50 Kütüphanesi" alanı zaten çıkıyor ve direk seçip referans olarak projemize ekleyebiliyoruz. NetOpenX50 apisinin kullanımı için her d...

SQL DATEADD() Fonksiyonu(Sql de tarihe ay,gün,yıl ekleme)

Kullanım Kalıbı : DATEADD (datepart , number , date ) . datepart ksımına month,year,day vs artırmak istediğimiz tarih birimini yazıyoruz. . number ksımına arttırmak istediğimiz miktarı yazıyoruz. . date kısmına da hangi tarih e ekleneceğini belirtiyoruz. Örnek olarak şu an ki tarihten 1 ay sonrasını görmek için : Şu anki tarih '10-1-2011' olsun(gün,ay,yıl) Sorgu : SELECT DATEADD(MONTH,+1,GETDATE()) Çıktı alacağımız tarih : '10-2-2011' şekinde olacaktır.

IEnumerable ile List Arasındaki Farklar

Sık kullandığımız iki tip olan IEnumerable ve List tipleri ile ilgili sürekli kullanılmasına rağmen farkının çok bilinmediğini düşünerek bu konuda kısa bir yazı yazmak istedim. Bakalım aralarında farklar nelermiş. IEnumerable bir interface iken, List yine IEnumerable sınıftan türeyen somut ( concrete) bir sınıftır. Arasındaki Farklar :  IEnumerable  - List e göre iteration çok daha hızlıdır. Performans için kullanılabilir.  - Read Only bir tip olduğu için Add, Remove gibi işlemler yapılamaz, IEnumerable ile sadece iteration, sort, filter gibi işlemler yapılabilir.  - Soyut bir class olduğu için istenen tipe somutlaştırılabilir.  - yield tipi ile birlikte kullanılabilir.(Promise veri döndürme,state-machine liste kullanımı)  - Linq sorguları veri tabanı sorgularınızın cevaplarınızı IEnumerable olarak döndürür, bu size siz ilgili IEnumerable list i iterate edene kadar ilgili sorguyu çalıştırmama performansı verir, böylece ilgili listeyi kullanmaya ihtiyacını...