YAZILIM MODELLEME VE TASARIMI

Benzer belgeler
YAZILIM MODELLEME VE TASARIMI

NESNEYE DAYALI YAZILIM GELİŞTİRME

C++ ile Nesneye Dayalı Programlama

Yazılım Örüntüleri (SE 461) Ders Detayları

Kalıtım (Inheritance)

YAZILIM MODELLEME VE TASARIM

Nesne İşaretçileri. Binnur Kurt Bilgisayar Mühendisliği Bölümü İstanbul Teknik Üniversitesi. Sınıf Yapısı. Kalıtım Çok Şekillilik

ANA SINIF TÜRETİLEN BİRİNCİ SINIF TÜRETİLEN İKİNCİ SINIF

YZM 2108 Yazılım Mimarisi ve Tasarımı

TÜMLEŞİK MODELLEME DİLİ. UML (Unified Modeling Language)

Bilgi Sistemleri Tasarımı (SE 503) Ders Detayları

Görsel Programlama DERS 02. Görsel Programlama - Ders02/ 1

NESNE YÖNELİMLİ PROGRAMLAMA HAFTA # 6. Yrd.Doç.Dr.Hacer Karacan

BİL-142 Bilgisayar Programlama II

YZM 2105 Nesneye Yönelik Programlama

YAZILIM MODELLEME VE TASARIM

Eylül 2007 de v1.0 ı yayınlanan SysML sayesinde endüstri mühendislerinin de ihtiyacı karşılanmış oldu.

Sınıf Diyagramları Amaç: Sınıf Diyagramları Nasıl Çizilir?

YZM 2105 Nesneye Yönelik Programlama

BMH-405 YAZILIM MÜHENDİSLİĞİ

BİL-141 Bilgisayar Programlama I (Java)

BTEP243 Ders 3. class Yazım Kuralı:

NESNE TABANLI PROGRAMLAMA

Operatörlere Yeni İşlevler Yüklenmesi (Operator Overloading)

NESNEYE YÖNELİK PROGRAMLAMA. Yrd.Doç.Dr. Zeynep ORMAN

Nesne Yönelimli Programlama

YAZILIM TASARIMI KALİTESİ (ÖLÇME VE DEĞERLENDİRME)

YZM 2105 Nesneye Yönelik Programlama

public class SalesLineItem // Java { private int quantity; private ProductSpecification description; public Money getsubtotal() {...

Binnur Kurt Bilgisayar Mühendisliği Bölümü İstanbul Teknik Üniversitesi. C++ ile Nesneye Dayalı Programlama 1

YZM 2105 Nesneye Yönelik Programlama

NESNE MODELLERİ : SINIFLAR

Nesneye Dayalı Analiz ve Tasarım (SE 321) Ders Detayları

Bir yazılım geliştirme metodolojisi aşağıdaki adımlardan meydana gelir; Yazılım geliştirme sürecine destek verecek araçlar, modeller ve yöntemler.

Programlama Dillerinde Kullanılan Veri Tipleri

Rapor Hazırlama Kuralları

Ders Notlarının Creative Commons lisansı Feza BUZLUCA ya aittir. Lisans:

Yaz.Müh.Ders Notları #4 1

Yazılım Mühendisliği 1

Çok Şekillilik (Polymorphism)

Java da Soyutlama ( Abstraction ) ve Çok-biçimlilik ( Polymorphism )

Yaz.Müh.Ders Notları #6 1

Fonksiyonlar. C++ ve NESNEYE DAYALI PROGRAMLAMA 51. /* Fonksiyon: kup Bir tamsayının küpünü hesaplar */ long int kup(int x) {

TEMPLATES. Binnur Kurt Bilgisayar Mühendisliği Bölümü İstanbul Teknik Üniversitesi. C++ ile Nesneye Dayalı Programlama 1

C++ Dersi: Nesne Tabanlı Programlama

YAZILIM KAVRAMINA BİR BAKIŞ. Gürcan Banger Elektrik Yük. Müh. ESOGÜ - 9 Nisan 2007

NESNEYE YÖNELİK PROGRAMLAMA Unified Modelling Language (UML) Bütünleşik Modelleme Dili

Java C.Thomas Wu 2004b kitabından Türkçeleştirilerek ve örneklendirilerek hazırlanmıştır.

YZM 2108 Yazılım Mimarisi ve Tasarımı

CENG 302 Yazılım Mühendisliği Yazılım Mimarisi - Devam. Alper UĞUR

SİSTEM VE YAZILIM. o Bilgisayar sistemleri donanım, yazılım ve bunları işletmek üzere gerekli işlemlerden oluşur.

Uzaktan Eğitim Uygulama ve Araştırma Merkezi

SOFTWARE ENGINEERING Ders İzlence Formu. Kodu:CSE400 Dersin Adı: SOFTWARE ENGINEERING Toplam Saat

NESNEYE YÖNELİK ÇÖZÜMLEME SÜRECİ

#ifndef COMPLEX_H #define COMPLEX_H

Bölüm 11. Soyut veri tipleri ve kapsülleme kavramları ISBN

NESNEYE DAYALI PROGRAMLAMA VE C++

YAZILIM MODELLEME VE TASARIM

YAZILIM MÜHENDİSLİĞİ TEKNOLOJİ FAKÜLTESİ / BİLGİSAYAR MÜHENDİSLİĞİ

Object-Oriented Programming Laboratuvar 11

HSancak Nesne Tabanlı Programlama I Ders Notları

MESLEKİ TERMİNOLOJİ I 1. HAFTA YAZILIM MÜH. TEMEL KAVRAMLAR

2. Iterasyon. Bu bölümde ele alınan problemler:

Bölüm 9. Altprogramlar ISBN

YAZILIM MÜHENDİSLİĞİ Şubat 2012 Yrd.Doç.Dr. Yunus Emre SELÇUK GENEL BİLGİLER

YZM 2108 Yazılım Mimarisi ve Tasarımı

VERİ YAPILARI LİSTELER. Yrd. Doç. Dr. Murat GÖK Bilgisayar Mühendisliği Bölümü YALOVA ÜNİVERSİTESİ

Ders Adı Kodu Yarıyılı T+U Saati Ulusal Kredisi AKTS

abstract Sınıflar 1 Sınıf sınıf1 new class Ama aşağıdaki şekilde referans alınabilir;

Mühendislik Fakültesi Elektrik-Elektronik Mühendisliği C Programlama 7. Bölüm Metot Tanımlama ve Kullanma

1 PROGRAMLAMAYA GİRİŞ

YZM 2116 Veri Yapıları

9.DERS Yazılım Geliştirme Modelleri

C++ Dersi: Nesne Tabanlı Programlama

Inheritance. Inheritance (turetim)

1. Aşağıdaki program parçacığını çalıştırdığınızda result ve param değişkenlerinin aldığı en son değerleri ve programın çıktısını yazınız.

BSM 532 KABLOSUZ AĞLARIN MODELLEMESİ VE ANALİZİ OPNET MODELER

Veritabanı Yönetim Sistemleri (Veritabanı Kavramı) Veri Modelleri

YAZILIM MODELLEME VE TASARIM

ARDIŞIL DİYAGRAM YAPI DİYAGRAMI. Sistem Analizi ve Tasarımı Dersi

Ders 8: Metotlar. barisgokce.com

Nesne Tabanlı Programlama (COMPE 225) Ders Detayları

JAVA PROGRAMLAMA DİLİ ÖZELLİKLERİ

Ders 8 Konu Özeti ve Problemler

C#(Sharp) Programlama Dili

Bilişim Sistemleri. Modelleme, Analiz ve Tasarım. Yrd. Doç. Dr. Alper GÖKSU

Sunum İçeriği. Programlamaya Giriş

NESNEYE YÖNELİK PROGRAMLAMA

BM208- Nesneye Dayalı Analiz ve Tasarım. Sunum 7

Maltepe Üniversitesi Bilgisayar Mühendisliği Bölümü Yazılım Mühendisliği II (BIL 306)

Kurucu Fonksiyonlar (Constructors)

BİL-142 Bilgisayar Programlama II

Rapor Hazırlama Kuralları

BLG Sistem Analizi ve Tasarımı. Öğr. Grv. Aybike ŞİMŞEK

BİLG Dr. Mustafa T. Babagil 1

Tarih Saat Modül Adı Öğretim Üyesi. 01/05/2018 Salı 3 Bilgisayar Bilimlerine Giriş Doç. Dr. Hacer Karacan

ENF102 TEMEL BİLGİSAYAR BİLİMLERİ VE C/ C++ PROGRAMLAMA DİLİ. Gazi Üniversitesi Mühendislik Fakültesi Bilgisayar Mühendisliği Bölümü

SİSTEM ANALİZİ VE TASARIMI

PROGRAMLAMAYA GİRİŞ. Öğr. Gör. Ayhan KOÇ. Kaynak: Algoritma Geliştirme ve Programlamaya Giriş, Dr. Fahri VATANSEVER, Seçkin Yay.

Kullanım Durumu Diyagramları (Use-case Diyagramları)

Transkript:

1 YAZILIM MODELLEME VE TASARIMI Yrd.Doç.Dr. Feza BUZLUCA İstanbul Teknik Üniversitesi Bilgisayar Mühendisliği Bölümü Ders Notlarının Creative Commons lisansı Feza BUZLUCA ya aittir. Lisans: http://creativecommons.org/licenses/by-nc-nd/3.0/ 1.1 Konuyu Anlamak Ve Derste Başarılı Olmak İçin Bu dersten yararlanabilmeniz için nesneye dayalı programlama (object oriented programming) kavramlarını bilmeniz gerekir. Özellikle kalıtım (inheritance) ve çok şekillilik (polymorphism) konularına hakim olmalısınız. Eğer nesneye dayalı programlama konusunda bilgi eksikliğiniz varsa Objectoriented programming ders notlarını mutlaka gözden geçiriniz. http://www.ninova.itu.edu.tr/tr/dersler/bilgisayar-bilisim-fakultesi/21/blg-252e/ekkaynaklar/ Ders notları dersin izlenmesini kolaylaştırmak için hazırlanmıştır. Ders notları tek başına konuyu tam olarak öğrenmek için yeterli değildir. Yüksek lisans / doktora öğrencisi olarak kendiniz de bu konuda araştırma yapmalı ve başka kaynaklardan da (kitap, bilimsel yayınlar, Internet) yararlanmalısınız. Dersin resmi web sitesi Ninova e-öğrenim sisteminde yer almaktadır. Derse kayıtlı olan öğrenciler sisteme (http://ninova.itu.edu.tr) İTÜ şifreleri ile girmeliler. Dersle ilgili tüm duyuruları ve ödevleri şifrenizle girerek takip ediniz. Sisteme şifresiz giren misafirler sadece ders notlarına erişebilirler. Derste edindiğiniz bilgileri uygulamanız için bir dönem projesi verilecektir. Dersler ilerledikçe proje üzerinde de çalışmalısınız. Projenin teslim tarihi ertelenmeyecektir. 1.2

2 GİRİŞ Yazılım Geliştirmenin Özellikleri ve Dersin Hedefi: Bu derste "endüstriyel boyutlu" yazılımlar ele alınacaktır. Bu tür yazılımlar bir çok işlevsel yeteneğe sahiptirler ve bir çok birimden oluşurlar. Gerçek dünyanın karmaşıklığı yazılımlara yansıyor. Bu nedenle günümüz yazılımları en az diğer mühendislik ürünleri (bina, köprü, taşıt yapımı) kadar karmaşıktır. Günümüzün modern yazılımları çok sayıda kişinin yer aldığı takımlar halinde yazılıyor. Yazılımlar bir çok modülden (sınıf, nesne, hizmet) oluşuyor. Bu da iyi bir iletişim altyapısı ve modüller arası uyum gerektirir. Yazılımlar sürekli gelişirler (değişirler!). Bu gelişme ve değişim hem yazılımın geliştirilmesi sürecinde hem de yazılım tamamlandıktan sonra olur. Bu nedenle esneklik çok önemlidir. Anahtar sözcükler: Karmaşıklık, iletişim (işbirliği), uyum, esneklik (değişim) 1.3 Yazılım Geliştirmenin Özellikleri ve Dersin Hedefi (devamı): Bir programlama dilini iyi bilmek kaliteli bir yazlım geliştirmek için yeterli değildir. Programlama (kodlama) zevkli bir konudur ama kaliteli bir yazılım sistemi oluşturmak daha karmaşık ve zor bir iştir. (Philippe Kruchten) İyi bir yazılım oluşturabilmek için uygun yazılım geliştirme tekniklerini de bilmek ve uygulamak gerekiyor. Yazılım Dünyasındaki sorun (The software crisis) Yazılımın zamanında tamamlanamaması Bütçenin aşılması, bakım maliyetlerinin yüksek olması, Bir çok hata çıkması ve bu hataların giderilememesi, Yazılımın yeni gereksinimlere göre uyarlanamaması, Eski projelerde hazırlanan yazılım modüllerinin yeni projelerde kullanılamaması Bu dersin amacı, yukarıda kısaca sıralanan sorunları gidererek kaliteli yazılımlar geliştirmeyi sağlayan Nesneye Dayalı Çözümleme ve Tasarım (Object-Oriented Analysis and Design OOA/D) yöntemlerini tanıtmaktır. 1.4

3 Yazılım (1) Deneyim Yazılım Mühendisi Temel amaç karmaşıklığı çözebilmek, değişimlerle baş edebilmek, esnek ve tekrar kullanılabilir yazılım sistemleri geliştirerek, maliyetleri düşürmek. (2) (1) http://www.photoeverywhere.co.uk (2) http://www.cafepress.co.uk/ Dersin Kapsamı: Dersin ilk bölümlerinde istekleri ve problemi (gerçeklenecek olan sistemi) anlamak için yapılması gereken çözümleme (analysis) üzerinde durulacaktır. Ardından sistemin, işbirliği yapan nesneler halinde nesneye dayalı olarak nasıl tasarlanacağı (design) açıklanacaktır. Analiz ve tasarımların ifade edilmesinde tümleşik modelleme dili (The Unified Modeling Language UML) kullanılacaktır. UML i ayrıntılı olarak öğretmek dersin hedefleri arasında yer almamaktadır, ancak UML diyagramları kullanılırken aynı zamanda bu dilin ders kapsamında kullanılan özellikleri tanıtılacaktır. Nesneye dayalı tasarım yapılırken yıllar içinde oluşan deneyimlerin yöntem haline dönüştürülmesi ile oluşturulan tasarım kalıplarından (design patterns) yararlanılır. Bu derste de tasarım aşamasında GRASP kalıpları ve yaygın biçimde kabul gören GoF kalıpları tanıtılacaktır. Son olarak yazılım kalitesinin ölçülmesinde ve değerlendirilmesinde kullanılan yazılım metrikleri ele alınacaktır. Öğrencilerin bu dersten yararlanabilmeleri için nesneye dayalı programlama (OOP) yöntemini ve bu yöntemi destekleyen dillerden birini (C++, Java, C#) bilmeleri gerekmektedir. 1.6

4 Nesneye Dayalı Analiz ve Tasarım NEDEN Gerekli? Yazılım Dünyasındaki Problemler: Donanım maliyetleri azalırken yazılım maliyetleri artmaktadır. Yazılımların boyutları ve karmaşıklığı artmaktadır. Yazılımların bakım maliyetleri çok yüksektir. Donanım problemleri ile çok az karşılaşılırken yazılım hataları sıklaşmaktadır. Yazılım Geliştirme Aşamalarının Maliyetleri: İsteklerin Çözümlenmesi (Requirements): %3 Tasarım: %8 Kodlama (Programlama): %7 Sınama: %15 Bakım: %67 (Maliyeti çok yüksek, neden?) Hataların Giderilme Maliyetleri (Belirlendikleri aşamaya göre): İsteklerin Çözümlenmesi (Requirements): 1 Birim Tasarım: 1.5-2 Birim Kodlama (Programlama): 5 10 Birim Sınama: 10 15 Birim Bakım: 15 100 Birim Hataların %85'i isteklerin çözümlenmesi ve tasarım aşamalarında oluşmaktadır. 1.7 Çözüm: Yazılım geliştirme: hem bir bilim dalı hem de bir sanat. Kolay ve kesin bir reçete yok. Sezgiler ve deneyim önemli. Aşağıdaki unsurlar doğru şekilde kullanıldıklarında işler kolaylaşıyor, başarı olasılığı yükseliyor. Uygun yazılım geliştirme süreçleri: Yinelemeli (iterative) ve evrimsel (evolutionary) yöntemler Tümleştirilmiş geliştirme süreci (The Unified Process UP) Programlama ve modelleme yöntemleri Nesneye Dayalı Yöntem Yardımcı araçlar UML (The Unified Modeling Language) Yazılım Geliştirme Programları Nesneye Dayalı Prensipler (Örneğin bağımlılığı sınırlayın) Tasarım kalıpları (Design Patterns) 1.8

5 Temel Kavramlar: Yazılım geliştirme aşamaları: İstekler (Requirements) Müşterilerin isteklerinin anlaşılması. Kullanım durumlarının (use case) yazılması. Problemin analizi (Domain analysis) Sistemin (problemin) anlaşılması. Sistem ne yapacak? Tasarım (Design) Sistemin işbirliği yapan nesneler şeklinde tasarlanması. Sorumlulukların sınıflara atanması. Gerçekleme (Implementation) Kodlama (Coding), programlama (programming) Değerlendirme (Evaluation) Sınama (testing), performans ölçümü ve değerlendirmesi, bakım Bu dersin ana konusu sorumlulukların sınıflara uygun şekilde atanmasıdır (tasarım). Ayrıca isteklerin anlaşılması ve analiz konusuna da değinilecektir. 1.9 Yazılım Mühendisinin Dünyası Problem Senaryolar Uygulama modeli Tasarım modeli Program (kod) Yazılım (ürün) Use case Tasarım prensipleri Tasarım kalıpları Analiz Programlama Dili Problem Uzayı Gerçek Dünya Soyutlama Modelleme Tasarım Gerçekleme Analist/ Yazılım Mimarı / Programcı (Yazılım Mühendisi) Yazılım Uzayı Program Çözüm Dünyası 1.10

6 Beklentiler ve Yazılım Mimarı (Software Architect) Kaynak: D. Falessi, G. Cantone, R. Kazman, and P. Kruchten, Decision-making techniques for software architecture design, ACM Computing Surveys, 2002 vol. 43, - 2012 pp. Dr. 1-28, Feza BUZLUCA Oct. 2011. 1.11 Nesneye Dayalı Çözümleme (Analysis): Yazılım mühendislerinin çok farklı alanlarda çalışması gerekebilir. Bu nedenle sadece yazılım konusunda (software domain ) bilgili olmaları yetmez çalıştıkları alanı da (problem domain ) tanımaları gerekir. Analiz aşamasında problem (uygulama) uzayındaki, yani gerçek dünyadaki sınıflar veya nesneler (kavramlar) belirlenip tanımlanır. Bu aşamada amaç problemi çözmek değil, anlamaktır. Örnek: Kütüphane otomasyonundaki kavramlar: Kütüphane, Kitap, Üye, Görevli vs. Nesneye Dayalı Tasarım (Design): Yazılım (çözüm) uzayındaki, yani bilgisayardaki sınıflar (ve nesneler) oluşturulur. Burada sınıfların içerikleri (özellik ve davranış) ve sınıflar arası ilişkiler tam olarak tanımlanır. Tasarım prensipleri ve kalıpları kullanılarak sorumluluklar uygun sınıflara atanır. Uygulama uzayı baslik Kitap Uygulama uzayı modeli Kitap -baslik: string +sayfa_git(int) Yazılım uzayı modeli class Kitap{ private: string baslik; public: void sayfa_git (int); } 1.12

7 Basit Bir Örnek: Ayrıntıya girmeden önce temel kavramlar basit bir örnek üzerinde gösterilecektir. Zar Oyunu: (C.Larman'ın kitabından alınmıştır.) Oyuncu iki zar atar. Zarların üste gelen yüzeylerindeki sayıların toplamı 7 ise oyuncu kazanır, aksi durumda kaybeder. 1. İsteklerin (Requirements) Belirlenmesi, Kullanım Senaryolarının (Use Case) Yazılması İstekleri belirlemek için kullanılan en geçerli yöntem, kullanım senaryoları (use case) yöntemidir. Bu yöntemde tasarımı yapılan sistem ile kullanıcıları arasında gerçekleşebilecek tüm olaylar numaralandırılarak adım adım yazılır. Örnek: Ana senaryo: 1. Oyuncu iki zarı yuvarlar. 2. Sistem zarların üstündeki değerleri ve toplamlarını gösterir. 3. Oyun sona erer. Alternatif akışlar: 2.a. Üste gelen değerlerin toplamı 7 dir. Sistem oyuncuya kazandığını bildirir. 2.b. Üste gelen değerlerin toplamı 7 den farklıdır. Sistem oyuncuya kaybettiğini bildirir. 1.13 2. Uygulama Uzayında Modelleme (Analiz) Uygulamayı (gerçeklenecek olan sistemi) oluşturan kavramlar (sınıflar), bunların özellikleri ve aralarındaki ilişkiler belirlenir. Bu aşamada elde edilen sınıflar gerçek dünyadaki sınıflardır. Oluşturulan modelin amacı problemi çözmek değil, anlamaktır. Bir oyuncu iki zar atar Sınıfın adı Oyuncu 1 atar 2 Zar Sınıfın niteliği isim 1 1 oynar üsttekideğer 2 Zar Oyunu 1 içerir düzey İlişkinin adı 1.14

8 3. Yazılım (Çözüm) Uzayında Modelleme (Tasarım) Bu aşamada tasarım yapılarak sistemin sorumlulukları tasarım kalıplarının yardımıyla uygun yazılım sınıflarına atanır. Tasarım sonucu iki farklı diyagram ile ifade edilir. a. Etkileşim Diyagramı: Sınıfların (nesnelerin) davranışları ve aralarındaki etkileşim belirlenir. ZarOyunu sınıfından yaratılan bir nesne :ZarOyunu zar1:zar zar2:zar Nesneye gelen mesaj sonuc:=oyna() yuvarlan() d1:=ustdegerver() Zar sınıfından yaratılan zar2 nesnesi Metodun gövdesi yuvarlan() d2:=ustdegerver() 1.15 b. Sınıf Diyagramı Sınıfların sahip olacakları üyeler (özellikler ve davranışlar) programda yer alacağı şekilde belirlenir. Bu aşamadaki model problemin çözümünü oluşturur. Yazılım sınıfı özel (private) nitelikler açık (public) metot ZarOyunu -zar1: Zar -zar2: Zar +oyna(): bool 1 2 Zar -ustdeger:int +ustdegerver():int +yuvarlan() Tasarımdan sonraki aşamalar: 4. Kodlama 5. Sınama İlişkinin (mesaj akışı) yönü Bu örnek ile kısaca açıklanan konular dersin ilerleyen bölümlerinde ayrıntılı olarak anlatılacaktır. 1.16

9 Bir Yazılımın Kalitesi Lisans: http://creativecommons.org/licenses/by-nc-nd/3.0/ Bir yazılım istenen işi doğru olarak yapmalıdır (useful). Program kolay kullanılabilir olmalıdır (usable). Program uygulamanın gerektirdiği kadar hızlı çalışmalıdır. Program, sistem kaynaklarını (işlemci, bellek, disk, iletişim ağı vb.) gerektiğinden daha fazla kullanmamalıdır. Yazılım sağlam olmalıdır. Yazılımı güncellemek kolay olmalıdır. kullanıcı Yazılımın bakımı (değişen isteklere uyum ve hata giderme) kolay olmalıdır. Yazılım projesi yeterli bir süre içinde tamamlanmalıdır. Yazılımın modülleri yeni projelerde tekrar kullanılabilmeli (reusable). Yazılımı geliştirme maliyeti düşük tutulabilmelidir. Yazılım geliştiren Programlama dilini bilmek yeterli değil. Programlama dilinin desteklediği yöntemleri iyi kullanabilmek gerekir. "Çekiç sahibi olmak kişiyi mimar yapmaz." 1.17 Nesneye Dayalı Programlama Kavramlarını Kısaca Anımsatma Sınıflar (Nesneler) Arasındaki İlişkiler (Relations) Bir uygulamanın yapısal analizi büyük ölçüde gerekli sınıfların ve sınıflar arasındaki ilişkilerin belirlenmesine dayanır. Nesneye dayalı dünyada sınıflar arasında; bağlantı (association), sahip olma (aggregation), -dan oluşma (composition), kalıtım (inheritance) gibi ilişkiler olur. Bağlantı (Association) Sınıflar arasında hizmet alma/vermeye dayalı ilişkidir. işveren 1 1..* çalıştırır işçi Çoğunlukla çift yönlüdür. Tek yönlü olduğu durumlarda ok kullanılır. işçi 1..* 1 Yanında çalışır işveren Nesneler arasındaki bağlantıya bağ (link) denir. 1.18

10 Sahip Olma (has a) İlişkisi (Aggregation / Compositon) Bir sınıfın üyeleri sadece hazır veri tipleri (char, int, double...) olmak zorunda değildir. Bir sınıfın üyeleri başka sınıftan tanımlanmış nesneler de olabilirler. Sahip olma ilişkisinin (has a relation) iki ayrı türü vardır: Toplama, bir araya getirme (Aggregation ): İçerilen nesneler (alt parçalar) kendi başlarına da kullanılırlar. Sadece o nesneye ait parçalar değillerdir. Örneğin havaalanında uçaklar vardır. 1 Hava alanı * Uçak UML sınıf diyagramında bu ilişki ifade edilirken kutucuğun içi boş bırakılır. Meydana gelme (Composition ): Alt parçalar o nesneyi meydana getirmek için oluşturulmuşlardır; kendi başlarına kullanılmazlar. Örneğin otomobilin motoru vardır. Otomobil 1 1 Motor UML sınıf diyagramında bu ilişki ifade edilirken kutucuğun içi doldurulur. 1.19 Temsil (Delegation) Nesneye dayalı programlamanın önemli kavramlarından biri de temsildir (delegation). Bir sınıf/nesne bazı hizmetleri yerine getirmek için başka varlıkları (sınıf/nesne) görevlendirebilir. Diğer bir deyişle kendisini temsil etmesini sağlar. Örnek: Bir yığın sınıfı tasarlanırken bu sınıfın içine daha önceden varolan bir liste sınıfı yerleştirilebilir. Yığın -içerik: Liste +push() +pop() 1 1 Yığın sınıfı push işlemi için Liste Liste sınıfının add hizmetini kullanacaktır.... +add() +remove() +first() +last() Temsil görevli nesne bulununcaya kadar birden fazla aşama sürebilir. 1.20

11 Kalıtım (Inhertiance), Generalization /Specialization Varolan genel bir sınıftan daha özel (ek niteliklere sahip) sınıflar türetilebilir. Bu türetimde üst sınıfın ayrıntılarının bilinmesine ve kaynak kodunun elde edilmesine gerek yoktur. Yararları: 1. Tekrar kullanılabilirlik (reusability). Sistemin genel kısımları önce kodlanır. Daha özel kısımlar genel kısımlardan türetilir. Ortak özelliklerin yeniden yazılmasına gerek kalmaz. 2. Çok şekillilik (polymorphism) ile birlikte kullanıldığında, aynı sınıftan türeyen farklı varlıkların onlara mesaj gönderen nesnelere aynı varlıklar gibi görünmesini sağlar. Yandaki örnek diyagramda Müdür bir öğretmendir (is a relation). Müdür öğretmenin tüm özelliklerine sahiptir, ayrıca ek özelliklere sahiptir. Üst sınıfın (öğretmen) istenen özellikleri alt sınıfta (müdür) değiştirilebilir (overriding). Öğretmen İsim Yaş Öğrenci sayısı Müdür Okul adı Öğretmen sayısı 1.21 Çok Şekillilik (Polymorphism) Aynı mesaja farklı sınıflardan yaratılmış olan nesneler farklı tepkiler verirler. Mesajı gönderen taraf bu mesajı hangi sınıftan bir nesneye gönderdiğini bilmek zorunda değildir. class Teacher{ // Base class string name; int numofstudents; public: Teacher(const string &, int); // Constructor of base virtual void print() const { cout << "Name: "<< name << endl; cout << " Num of Students:"<< numofstudents << endl;} }; class Principal : public Teacher{ // Derived class string SchoolName; public: Principal(const string &, int, const string &); void print() const { Teacher::print(); cout << " Name of School:"<< SchoolName << endl;} }; 1.22

12 Lisans: http://creativecommons.org/licenses/by-nc-nd/3.0/ void show (const Teacher * tp) { tp->print(); // hangi print } // Test amaçlı main int main() { Teacher t1("teacher 1",50); Principal p1("principal 1",40,"School"); Teacher *ptr; char c; cout << "Teacher or Principal "; cin >> c; if (c=='t') ptr=&t1; else ptr=&p1; show(ptr); // hangi print? : Eğer print fonksiyonu C++ dilinde sanal (virtual) olarak tanımlanmazsa show fonksiyonunda her zaman Teacher sınıfındaki fonksiyon çağırılır. print fonksiyonu sanal olarak tanımlandığında çok şekillilik özelliği kazanır. Bu durumda tp işaretçisi hangi tipte bir nesneye işaret ediyorsa ona ait sınıftaki print fonksiyonu canlanır. Bu durumda hangi metodun çağırılacağına program çalışırken (run-time) karar verilmiş olur. Çok şekillilik esneklik sağlar. Yukarıdaki örnekte show fonksiyonu Teacher sınıfından türeyen tüm sınıfların nesneleri üzerinde işlem yapabilir. Örnek olarak ileride Teacher sınıfından türetilerek stajyer öğretmenleri tanımlamak üzere InternTeacher adlı yeni bir sınıf sisteme katılsa show fonksiyonunda bir değişiklik yapmaya gerek olmaz. 1.23 Örnek tasarımın UML diyagramı: Show modülündeki tp işaretçisi Teacher sınıfından türetilen tüm sınıfların nesnelerine işaret edebilir. Show tp Teacher print() Bu sınıfın eklenmesi Show modülünü etkilemez. Principal InternTeacher print() print() 1.24

13 C++ dilinde işaretçiler yerine kullanımı daha basit olan referans tipi de (&) kullanılabilir. Aşağıdaki örnekte show fonksiyonun giriş parametresi referans tipindedir. // Show is a system that operates on Teachers and Principals void show (const Teacher & tp) { tp.print(); // which print } // Only to test the show function int main() { Teacher t1("teacher 1", 50); Principal p1("principal 1", 40, "School"); char c; cout << "Teacher or Principal " ; cin >> c; if (c == 't') show(t1); else show(p1); : Eğer nesneye dayalı programlama konusunda bilgi eksikliğiniz varsa Objectoriented programming ders notlarını mutlaka gözden geçiriniz. http://www.ninova.itu.edu.tr/tr/dersler/bilgisayar-bilisim-fakultesi/21/blg-252e/ekkaynaklar/ 1.25 Modellemenin Önemi ve Yararı: Uygulama (analiz) modeli gerçek dünyadaki problemi ve üzerinde çalışacağımız sistemi doğru şekilde anlamamızı sağlar. Tasarım modeli sistemin tüm gerekli işlevlerinin (sorumluluklarının) sağlanıp sağlanmadığının görülmesini sağlar. Bu model ayrıca tasarımımızı güvenlik, esneklik gibi ölçütlere göre sınamamızı ve değerlendirmemizi de sağlar. Model tasarım ile ilgili kararlarımızı daha kolay sunmamızı ve açıklamamızı sağlar. Bu durum takım içi iletişimi ve çalışmayı kolaylaştırır. Modeller gerekli düzeltme ve değişikliklerin yazılım geliştirmenin erken aşamalarında yapılmasını sağlarlar. Bu da maliyeti düşürür. Örneğin uçaklar üretilmeden önce tasarımlarını fiberglastan modeli yapılır ve bu model rüzgar tünelinde sınanır. Progress is possible only if we train ourselves to think about programs without thinking of them as pieces of executable code. Edsger W. Djikstra (1930-2002) 1.26

14 Ana kaynak: Kaynak Kitaplar: Craig Larman, Applying UML and Patterns, An Introduction to OOA/D and Iterative Development, 3/e, 2005. Diğer Kaynaklar: Eric & Elisabeth Freeman: Head First Design Patterns, O REILLY, 2004. Gamma E., Helm R., Johnson R., Vlissides J., Design Patterns : Elements of Reusable Object-Oriented Software, Reading MA, Addison-Wesley, 1995. 1.27