Ana içeriğe atla

SOLID Object Oriented Programing Principles

SOLID program yazarken (ideal program) kullanmamız gereken bazı kuralların ya da tasarımların baş harflerinin kısaltmasıdır.5 adet standart kuralımız vardır.Bu arada tasarımın tanımını daha önceden yapmıştık ancak hatırlatmada fayda var.Tasarımla seneler boyunca bir çok programcının karşısına çıkan sorunların çözümlenmiş şekilde en ideal olarak sunulmuş halidir.Bizimde Amerikayı tekrardan keşfetmemize tabiki gerek yok.Üstadlarımızın tavsiyelerine , oluşturdukları prensiplere ve kurallara uyarak gayet düzgün programlar yazabiliriz ve bunları testable şekilde sunarız.Uzun lafın kısası konumuza geri dönüyorum.

Single Responsibility - Her kullanılan modülün tek bir işlevi olmalı ve olası bir değişiklikte tek bir nedene dayanmalıdır.

Open/Closed - Kodumuz geliştirmeye açık yeniden yapılanmaya kapalı olmalıdır.Refactoring ve ya metodun tekrardan yazılması gibi bir durum söz konusu olmamalıdır.

Liskov's Substitution - Türeyen sınıf üyeleri ile temel sınıfın üyelerinin aralarında değişimi mümkün olmalıdır.Bu aynı zamanda Design Patternlerden Design by Contract  yapısıyla aynı işlevdedir.

Interface Segregation - Kullanıcan interfaceler mümkün oldukça birbirinden ayrı yazılmalıdır.Bir interface bir çok iş için kullanılabilir.Ancak gereksiz metod yüklemesine neden oluyor ise bu durumda birden fazla interface oluşturmak daha mantıklı olacaktır.

Dependency Inversion - High level classlar , low level classlara direkt olarak bağımlı olmamalıdır.Böyle bir durumda classlar arası düzenleme gerektiğinden birden fazla sorunla karşı karşıya kalınabilir.Arada bir abstract yada interface (duruma göre hangisi gerekiyorsa) kullanılmalıdır.

Yorumlar

Bu blogdaki popüler yayınlar

Merge-Sort için güzel bir video

Haftanın Sorusu

Evet arkadaşlar hedef kitlemi ve okuyucularımızın hepsi Bilgisayar Mühendisliği 1. sınıf yada 2. sınıf olduğu için C programlamaya başlangıç aşamasında bir soru yazıyorum.Soru elimdeki bir kitaptan alıntıdır.Cevap bir çok çeşitte olabilir.Kitapta cevap yok kendimiz halledeceğiz :) Kolay gelsin.Bunu da bir gelenek haline getirip her hafta biraz daha zor sorular yazalım.Cevabın kodlarını ister dosya olarak ister normal yazı şeklinde yoruma bırakabilirsiniz. Soru şöyle: Günde ortalama ... km yol yürüyen bir insan doğumundan bugüne kadar dünyanın çevresini kaç kez dolaşacak kadar yürümüş olur?(dünyanın çevresini 40.000 km olarak alınız,İnsanın kaç yaşında olduğu ve günde kaç km yürüdüğü bilgisini kullanıcıdan isteyiniz.)

Bilgisayar Mühendisliğine Giriş

Öncelikle Bilgisayar Mühendisliği alanına yeni başlamış biri olarak sadece gözlemlerimi ve edindiklerimi yazacağımı söylemem lazım.Konularla alakalı daha bilgili olan arkadaşlarımız varsa mailden yada aşağıdan yorum yaparak bana ulaşabilirler.Bende bilgi alışverişinde bulunmaktan memnun olurum :) . Şimdi İstanbul üniversitesi Bilgisayar Mühendisliği 1. sınıf güz yarıyılında alınan dersler; İntroduction to Algorithm Discrete Mathematics Calculus 1 Fizik 1 BMG Seçmeli dersleri saymıyorum çünkü onlar konuyla alakasız ve her üniversite 1. sınıf öğrencisine verilen ortak derslerdir.Şimdi burada benim kişisel görüşüm olarak en önemli ve zor olan ders Algoritmalar.Algoritmalara bilmeyenler için bir yazılımın genel tablosu olarak söylenebilir.Bu derste özellikle 1 tane proglama diline yönelinmez genel olarak hepsinde mantığın kavranması için verilir.Ama uygulama dersinde eski ama her daim kullanılan C dilince örneklemeler yapılıyor.(En azından İÜ'de böyle)Ders ingilizce anlatılıyo...