OOAD - Desain Berorientasi Objek

Setelah tahap analisis, model konseptual dikembangkan lebih lanjut menjadi model berorientasi objek dengan menggunakan desain berorientasi objek (OOD). Dalam OOD, konsep yang tidak bergantung pada teknologi dalam model analisis dipetakan ke kelas implementasi, batasan diidentifikasi, dan antarmuka dirancang, menghasilkan model untuk domain solusi. Singkatnya, deskripsi rinci dibangun menentukan bagaimana sistem akan dibangun di atas teknologi beton

Tahapan untuk desain berorientasi objek dapat diidentifikasi sebagai -

  • Definisi konteks sistem
  • Merancang arsitektur sistem
  • Identifikasi objek dalam sistem
  • Konstruksi model desain
  • Spesifikasi antarmuka objek

Desain sistem

Perancangan sistem berorientasi objek melibatkan pendefinisian konteks suatu sistem diikuti dengan perancangan arsitektur sistem.

  • Context- Konteks suatu sistem memiliki bagian yang statis dan dinamis. Konteks statis dari sistem dirancang dengan menggunakan diagram blok sederhana dari keseluruhan sistem yang dikembangkan menjadi hierarki subsistem. Model subsistem diwakili oleh paket UML. Konteks dinamis menggambarkan bagaimana sistem berinteraksi dengan lingkungannya. Itu dimodelkan menggunakanuse case diagrams.

  • System Architecture- Arsitektur sistem dirancang atas dasar konteks sistem sesuai dengan prinsip-prinsip desain arsitektur serta pengetahuan domain. Biasanya, sistem dipartisi menjadi beberapa lapisan dan setiap lapisan didekomposisi untuk membentuk subsistem.

Dekomposisi Berorientasi Objek

Dekomposisi berarti membagi sistem kompleks yang besar menjadi hierarki komponen yang lebih kecil dengan kompleksitas yang lebih rendah, berdasarkan prinsip divide – and-conquer. Setiap komponen utama sistem disebut subsistem. Dekomposisi berorientasi objek mengidentifikasi objek otonom individu dalam sistem dan komunikasi di antara objek-objek ini.

Keuntungan dekomposisi adalah -

  • Komponen individu memiliki kompleksitas yang lebih rendah, sehingga lebih mudah dipahami dan dikelola.

  • Ini memungkinkan pembagian tenaga kerja yang memiliki keterampilan khusus.

  • Ini memungkinkan subsistem diganti atau dimodifikasi tanpa mempengaruhi subsistem lain.

Mengidentifikasi Concurrency

Concurrency memungkinkan lebih dari satu objek untuk menerima kejadian pada waktu yang sama dan lebih dari satu aktivitas untuk dieksekusi secara bersamaan. Konkurensi diidentifikasi dan direpresentasikan dalam model dinamis.

Untuk mengaktifkan konkurensi, setiap elemen serentak diberi thread kontrol terpisah. Jika konkurensi berada pada level objek, maka dua objek bersamaan diberikan dua thread kontrol yang berbeda. Jika dua operasi dari satu objek bersifat bersamaan, maka objek itu akan dibagi di antara utas yang berbeda.

Konkurensi dikaitkan dengan masalah integritas data, kebuntuan, dan kelaparan. Jadi strategi yang jelas perlu dibuat kapan pun konkurensi diperlukan. Selain itu, konkurensi perlu diidentifikasi pada tahap desain itu sendiri, dan tidak dapat ditinggalkan untuk tahap implementasi.

Mengidentifikasi Pola

Saat merancang aplikasi, beberapa solusi yang diterima secara umum diadopsi untuk beberapa kategori masalah. Ini adalah pola desainnya. Sebuah pola dapat didefinisikan sebagai sekumpulan blok bangunan terdokumentasi yang dapat digunakan dalam jenis masalah pengembangan aplikasi tertentu.

Beberapa pola desain yang umum digunakan adalah -

  • Pola fasad
  • Pola pemisahan tampilan model
  • Pola pengamat
  • Pola pengontrol tampilan model
  • Publikasikan pola berlangganan
  • Pola proxy

Mengontrol Acara

Selama desain sistem, kejadian yang mungkin terjadi pada objek sistem perlu diidentifikasi dan ditangani dengan tepat.

Peristiwa adalah spesifikasi peristiwa penting yang memiliki lokasi dalam ruang dan waktu.

Ada empat jenis peristiwa yang dapat dimodelkan, yaitu -

  • Signal Event - Sebuah benda bernama dilempar oleh satu benda dan tertangkap oleh benda lain.

  • Call Event - Peristiwa sinkron yang mewakili pengiriman suatu operasi.

  • Time Event - Acara yang mewakili perjalanan waktu.

  • Change Event - Suatu peristiwa yang mewakili perubahan keadaan.

Penanganan Kondisi Batas

Tahap desain sistem perlu membahas inisialisasi dan penghentian sistem secara keseluruhan serta setiap subsistem. Berbagai aspek yang didokumentasikan adalah sebagai berikut -

  • Start-up sistem, yaitu transisi sistem dari kondisi tidak diinisialisasi ke kondisi tunak.

  • Penghentian sistem, yaitu penutupan semua utas yang berjalan, pembersihan sumber daya, dan pesan yang akan dikirim.

  • Konfigurasi awal sistem dan konfigurasi ulang sistem bila diperlukan.

  • Meramalkan kegagalan atau penghentian sistem yang tidak diinginkan.

Kondisi batas dimodelkan menggunakan kasus penggunaan batas.

Desain Objek

Setelah hierarki subsistem dikembangkan, objek dalam sistem diidentifikasi dan detailnya dirancang. Di sini, perancang merinci strategi yang dipilih selama perancangan sistem. Penekanannya bergeser dari konsep domain aplikasi ke konsep komputer. Objek yang diidentifikasi selama analisis diukir untuk implementasi dengan tujuan meminimalkan waktu eksekusi, konsumsi memori, dan biaya keseluruhan.

Desain objek mencakup fase-fase berikut -

  • Identifikasi objek
  • Representasi objek, yaitu konstruksi model desain
  • Klasifikasi operasi
  • Desain algoritme
  • Desain hubungan
  • Penerapan kontrol untuk interaksi eksternal
  • Mengemas kelas dan asosiasi ke dalam modul

Identifikasi Objek

Langkah pertama dari desain objek adalah identifikasi objek. Objek yang diidentifikasi dalam fase analisis berorientasi objek dikelompokkan ke dalam kelas-kelas dan disempurnakan sehingga sesuai untuk implementasi yang sebenarnya.

Fungsi dari tahap ini adalah -

  • Mengidentifikasi dan menyempurnakan kelas di setiap subsistem atau paket

  • Mendefinisikan tautan dan asosiasi antar kelas

  • Mendesain asosiasi hierarkis antar kelas, yaitu generalisasi / spesialisasi dan pewarisan

  • Merancang agregasi

Representasi Objek

Setelah kelas diidentifikasi, mereka perlu direpresentasikan menggunakan teknik pemodelan objek. Tahap ini pada dasarnya melibatkan pembuatan diagram UML.

Ada dua jenis model desain yang perlu diproduksi -

  • Static Models - Untuk mendeskripsikan struktur statis suatu sistem menggunakan diagram kelas dan diagram objek.

  • Dynamic Models - Untuk mendeskripsikan struktur dinamis dari suatu sistem dan menunjukkan interaksi antar kelas menggunakan diagram interaksi dan diagram diagram keadaan.

Klasifikasi Operasi

Pada langkah ini, operasi yang akan dilakukan pada objek ditentukan dengan menggabungkan tiga model yang dikembangkan dalam fase OOA, yaitu model objek, model dinamis, dan model fungsional. Operasi menentukan apa yang harus dilakukan dan bukan bagaimana cara melakukannya.

Tugas berikut dilakukan terkait operasi -

  • Diagram transisi status setiap objek dalam sistem dikembangkan.

  • Operasi ditentukan untuk peristiwa yang diterima oleh objek.

  • Kasus di mana satu peristiwa memicu peristiwa lain di objek yang sama atau berbeda diidentifikasi.

  • Sub-operasi dalam tindakan diidentifikasi.

  • Tindakan utama diperluas ke diagram aliran data.

Desain Algoritma

Operasi di objek ditentukan menggunakan algoritma. Algoritme adalah prosedur bertahap yang memecahkan masalah yang ditetapkan dalam operasi. Algoritme berfokus pada bagaimana hal itu dilakukan.

Mungkin ada lebih dari satu algoritme yang sesuai dengan operasi tertentu. Setelah algoritma alternatif diidentifikasi, algoritma optimal dipilih untuk domain masalah yang diberikan. Metrik untuk memilih algoritma yang optimal adalah -

  • Computational Complexity - Kompleksitas menentukan efisiensi suatu algoritma dalam hal waktu komputasi dan kebutuhan memori.

  • Flexibility - Fleksibilitas menentukan apakah algoritme yang dipilih dapat diimplementasikan dengan sesuai, tanpa kehilangan kesesuaian di berbagai lingkungan.

  • Understandability - Ini menentukan apakah algoritme yang dipilih mudah dipahami dan diterapkan.

Desain Hubungan

Strategi untuk mengimplementasikan hubungan perlu dituliskan selama fase desain objek. Hubungan utama yang ditangani terdiri dari asosiasi, agregasi, dan warisan.

Perancang harus melakukan hal berikut terkait asosiasi -

  • Identifikasi apakah pengaitan searah atau dua arah.

  • Analisis jalur asosiasi dan perbarui jika perlu.

  • Menerapkan asosiasi sebagai objek yang berbeda, jika ada hubungan banyak-ke-banyak; atau sebagai tautan ke objek lain jika ada hubungan satu-ke-satu atau satu-ke-banyak.

Mengenai warisan, desainer harus melakukan hal berikut -

  • Sesuaikan kelas dan asosiasinya.

  • Identifikasi kelas abstrak.

  • Buat ketentuan agar perilaku dibagikan saat dibutuhkan.

Penerapan Pengendalian

Perancang objek dapat memasukkan perbaikan dalam strategi model diagram negara. Dalam perancangan sistem dibuat strategi dasar untuk mewujudkan model dinamis. Selama desain objek, strategi ini sangat tepat untuk implementasi yang tepat.

Pendekatan untuk implementasi model dinamis adalah -

  • Represent State as a Location within a Program- Ini adalah pendekatan berbasis prosedur tradisional dimana lokasi kontrol mendefinisikan status program. Mesin negara hingga dapat diimplementasikan sebagai program. Transisi membentuk pernyataan input, jalur kontrol utama membentuk urutan instruksi, cabang membentuk kondisi, dan jalur mundur membentuk loop atau iterasi.

  • State Machine Engine- Pendekatan ini secara langsung merepresentasikan mesin status melalui kelas mesin mesin status. Kelas ini mengeksekusi mesin status melalui serangkaian transisi dan tindakan yang disediakan oleh aplikasi.

  • Control as Concurrent Tasks- Dalam pendekatan ini, suatu objek diimplementasikan sebagai tugas dalam bahasa pemrograman atau sistem operasi. Di sini, acara diimplementasikan sebagai panggilan antar-tugas. Ini mempertahankan konkurensi yang melekat pada objek nyata.

Kelas Pengemasan

Dalam proyek besar apa pun, partisi implementasi yang cermat ke dalam modul atau paket adalah penting. Selama desain objek, kelas dan objek dikelompokkan ke dalam paket untuk memungkinkan beberapa grup bekerja secara kooperatif dalam sebuah proyek.

Berbagai aspek pengemasan adalah -

  • Hiding Internal Information from Outside View - Memungkinkan kelas untuk dilihat sebagai "kotak hitam" dan mengizinkan implementasi kelas untuk diubah tanpa memerlukan klien kelas untuk memodifikasi kode.

  • Coherence of Elements - Sebuah elemen, seperti kelas, operasi, atau modul, adalah koheren jika diorganisasikan pada rencana yang konsisten dan semua bagiannya terkait secara intrinsik sehingga mereka melayani tujuan bersama.

  • Construction of Physical Modules - Panduan berikut membantu saat membangun modul fisik -

    • Kelas dalam modul harus mewakili hal atau komponen yang serupa dalam objek gabungan yang sama.

    • Kelas yang berhubungan erat harus berada dalam modul yang sama.

    • Kelas yang tidak terhubung atau terhubung lemah harus ditempatkan dalam modul terpisah.

    • Modul harus memiliki kohesi yang baik, yaitu kerjasama yang tinggi antar komponennya.

    • Sebuah modul harus memiliki kopling rendah dengan modul lain, yaitu interaksi atau interdependensi antar modul harus minimal.

Optimasi Desain

Model analisis menangkap informasi logis tentang sistem, sedangkan model desain menambahkan detail untuk mendukung akses informasi yang efisien. Sebelum diimplementasikan, desain harus dioptimalkan agar implementasi lebih efisien. Tujuan pengoptimalan adalah untuk meminimalkan biaya dalam hal waktu, ruang, dan metrik lainnya.

Namun, optimasi desain tidak boleh berlebihan, karena kemudahan implementasi, pemeliharaan, dan ekstensibilitas juga menjadi perhatian penting. Seringkali terlihat bahwa desain yang dioptimalkan dengan sempurna lebih efisien tetapi kurang dapat dibaca dan digunakan kembali. Jadi desainer harus menjaga keseimbangan antara keduanya.

Berbagai hal yang dapat dilakukan untuk pengoptimalan desain adalah -

  • Tambahkan asosiasi yang berlebihan
  • Hilangkan asosiasi yang tidak dapat digunakan
  • Optimasi algoritma
  • Simpan atribut turunan untuk menghindari penghitungan ulang ekspresi kompleks

Penambahan Asosiasi Redundan

Selama pengoptimalan desain, akan diperiksa apakah memperoleh asosiasi baru dapat mengurangi biaya akses. Meskipun asosiasi redundan ini mungkin tidak menambahkan informasi apa pun, mereka dapat meningkatkan efisiensi model secara keseluruhan.

Penghilangan Asosiasi yang Tidak Dapat Digunakan

Kehadiran terlalu banyak asosiasi dapat membuat sistem tidak dapat dipahami dan karenanya mengurangi efisiensi sistem secara keseluruhan. Jadi, selama pengoptimalan, semua pengaitan yang tidak dapat digunakan dihapus.

Optimasi Algoritma

Pada sistem berorientasi objek, optimalisasi struktur data dan algoritma dilakukan secara kolaboratif. Setelah desain kelas diterapkan, operasi dan algoritme perlu dioptimalkan.

Optimasi algoritma diperoleh dengan -

  • Penyusunan ulang urutan tugas komputasi
  • Pembalikan urutan eksekusi loop dari yang ditetapkan dalam model fungsional
  • Penghapusan jalur mati dalam algoritme

Menyimpan dan Menyimpan Atribut Turunan

Atribut turunan adalah atribut yang nilainya dihitung sebagai fungsi dari atribut lain (atribut dasar). Penghitungan ulang nilai atribut turunan setiap kali diperlukan adalah prosedur yang memakan waktu. Untuk menghindari hal ini, nilai dapat dihitung dan disimpan dalam bentuk penghitungannya.

Namun, hal ini dapat menimbulkan anomali pembaruan, yaitu perubahan nilai atribut dasar tanpa perubahan yang sesuai dalam nilai atribut turunan. Untuk menghindarinya, langkah-langkah berikut diambil -

  • Dengan setiap pembaruan nilai atribut dasar, atribut turunan juga dihitung ulang.

  • Semua atribut turunan dihitung ulang dan diperbarui secara berkala dalam grup daripada setelah setiap pembaruan.

Dokumentasi Desain

Dokumentasi adalah bagian penting dari setiap proses pengembangan perangkat lunak yang mencatat prosedur pembuatan perangkat lunak. Keputusan desain perlu didokumentasikan untuk sistem perangkat lunak non-sepele untuk mentransmisikan desain ke orang lain.

Area Penggunaan

Meskipun merupakan produk sekunder, dokumentasi yang baik sangat diperlukan, terutama di bidang berikut -

  • Dalam merancang perangkat lunak yang sedang dikembangkan oleh sejumlah pengembang
  • Dalam strategi pengembangan perangkat lunak berulang
  • Dalam mengembangkan versi proyek perangkat lunak selanjutnya
  • Untuk mengevaluasi perangkat lunak
  • Untuk menemukan kondisi dan area pengujian
  • Untuk pemeliharaan perangkat lunak.

Isi

Dokumentasi yang bermanfaat pada dasarnya harus mencakup konten berikut -

  • High–level system architecture - Proses diagram dan diagram modul

  • Key abstractions and mechanisms - Diagram kelas dan diagram objek.

  • Scenarios that illustrate the behavior of the main aspects - Diagram perilaku

fitur

Fitur dokumentasi yang baik adalah -

  • Ringkas dan pada saat yang sama, tidak ambigu, konsisten, dan lengkap

  • Dapat ditelusuri ke spesifikasi kebutuhan sistem

  • Well-structured

  • Diagram, bukan deskriptif