Strategi Desain Perangkat Lunak
Perancangan perangkat lunak adalah proses untuk mengkonseptualisasikan kebutuhan perangkat lunak ke dalam implementasi perangkat lunak. Desain perangkat lunak mengambil kebutuhan pengguna sebagai tantangan dan mencoba menemukan solusi yang optimal. Sementara perangkat lunak sedang dikonseptualisasikan, sebuah rencana dibuat untuk menemukan desain terbaik untuk menerapkan solusi yang diinginkan.
Ada beberapa varian desain perangkat lunak. Mari kita pelajari secara singkat:
Desain Terstruktur
Desain terstruktur merupakan konseptualisasi masalah menjadi beberapa elemen solusi yang tertata rapi. Ini pada dasarnya berkaitan dengan desain solusi. Manfaat desain terstruktur adalah memberikan pemahaman yang lebih baik tentang bagaimana masalah diselesaikan. Desain terstruktur juga memudahkan desainer untuk berkonsentrasi pada masalah dengan lebih akurat.
Desain terstruktur sebagian besar didasarkan pada strategi 'bagi dan taklukkan' di mana suatu masalah dipecah menjadi beberapa masalah kecil dan setiap masalah kecil diselesaikan secara individual hingga keseluruhan masalah terpecahkan.
Potongan-potongan kecil masalah diselesaikan dengan menggunakan modul solusi. Penekanan desain terstruktur bahwa modul-modul ini diatur dengan baik untuk mencapai solusi yang tepat.
Modul-modul ini disusun dalam hierarki. Mereka berkomunikasi satu sama lain. Desain terstruktur yang baik selalu mengikuti beberapa aturan komunikasi antar banyak modul, yaitu -
Cohesion - pengelompokan semua elemen yang terkait secara fungsional.
Coupling - komunikasi antar modul yang berbeda.
Desain terstruktur yang baik memiliki kohesi tinggi dan pengaturan kopling rendah.
Desain Berorientasi Fungsi
Dalam desain berorientasi fungsi, sistem terdiri dari banyak sub-sistem yang lebih kecil yang dikenal sebagai fungsi. Fungsi-fungsi ini mampu melakukan tugas penting dalam sistem. Sistem dianggap sebagai tampilan atas dari semua fungsi.
Desain berorientasi fungsi mewarisi beberapa properti desain terstruktur di mana metodologi divide and conquer digunakan.
Mekanisme desain ini membagi keseluruhan sistem menjadi fungsi-fungsi yang lebih kecil, yang menyediakan sarana abstraksi dengan menyembunyikan informasi dan operasinya. Modul fungsional ini dapat berbagi informasi di antara mereka sendiri melalui penyampaian informasi dan menggunakan informasi yang tersedia secara global.
Karakteristik lain dari fungsi adalah ketika suatu program memanggil suatu fungsi, fungsi tersebut mengubah status program, yang terkadang tidak dapat diterima oleh modul lain. Desain berorientasi fungsi bekerja dengan baik di mana status sistem tidak menjadi masalah dan program / fungsi bekerja pada input daripada pada status.
Proses Desain
- Keseluruhan sistem dilihat sebagai bagaimana data mengalir dalam sistem melalui diagram arus data.
- DFD menggambarkan bagaimana fungsi mengubah data dan keadaan seluruh sistem.
- Seluruh sistem secara logis dipecah menjadi unit-unit yang lebih kecil yang dikenal sebagai fungsi berdasarkan operasinya dalam sistem.
- Setiap fungsi kemudian dijelaskan secara luas.
Desain Berorientasi Objek
Desain berorientasi objek bekerja di sekitar entitas dan karakteristiknya alih-alih fungsi yang terlibat dalam sistem perangkat lunak. Strategi desain ini berfokus pada entitas dan karakteristiknya. Seluruh konsep solusi perangkat lunak berputar di sekitar entitas yang terlibat.
Mari kita lihat konsep penting dari Desain Berorientasi Objek:
- Objects - Semua entitas yang terlibat dalam desain solusi dikenal sebagai objek. Misalnya orang, bank, perusahaan dan nasabah diperlakukan sebagai objek. Setiap entitas memiliki beberapa atribut yang terkait dengannya dan memiliki beberapa metode untuk dilakukan pada atribut.
Classes - Kelas adalah deskripsi umum dari suatu objek. Objek adalah turunan dari kelas. Kelas mendefinisikan semua atribut, yang dapat dimiliki objek dan metode, yang mendefinisikan fungsionalitas objek.
Dalam desain solusi, atribut disimpan sebagai variabel dan fungsionalitas ditentukan melalui metode atau prosedur.
- Encapsulation - Dalam OOD, atribut (variabel data) dan metode (operasi pada data) digabungkan bersama disebut enkapsulasi. Enkapsulasi tidak hanya menggabungkan informasi penting dari suatu objek, tetapi juga membatasi akses data dan metode dari dunia luar. Ini disebut penyembunyian informasi.
- Inheritance - OOD memungkinkan kelas serupa untuk ditumpuk secara hierarkis di mana kelas yang lebih rendah atau sub-kelas dapat mengimpor, menerapkan dan menggunakan kembali variabel dan metode yang diizinkan dari kelas super langsung mereka. Properti OOD ini dikenal sebagai warisan. Ini membuatnya lebih mudah untuk menentukan kelas tertentu dan untuk membuat kelas umum dari kelas tertentu.
- Polymorphism - Bahasa OOD menyediakan mekanisme di mana metode yang melakukan tugas serupa tetapi berbeda dalam argumen, dapat diberi nama yang sama. Ini disebut polimorfisme, yang memungkinkan satu antarmuka melakukan tugas untuk berbagai jenis. Bergantung pada bagaimana fungsi tersebut dipanggil, masing-masing bagian dari kode akan dieksekusi.
Proses Desain
Proses desain perangkat lunak dapat dianggap sebagai serangkaian langkah yang didefinisikan dengan baik. Meskipun itu bervariasi sesuai dengan pendekatan desain (berorientasi fungsi atau berorientasi objek, namun mungkin ada langkah-langkah berikut yang terlibat:
- Sebuah desain solusi dibuat dari persyaratan atau sistem yang digunakan sebelumnya dan / atau diagram urutan sistem.
- Objek diidentifikasi dan dikelompokkan ke dalam kelas atas nama kesamaan dalam karakteristik atribut.
- Hierarki kelas dan hubungan di antara mereka didefinisikan.
- Kerangka aplikasi ditentukan.
Pendekatan Desain Perangkat Lunak
Berikut adalah dua pendekatan umum untuk perancangan perangkat lunak:
Desain Top Down
Kita tahu bahwa suatu sistem terdiri dari lebih dari satu sub-sistem dan berisi sejumlah komponen. Selanjutnya, sub-sistem dan komponen ini mungkin memiliki satu set sub-sistem dan komponen dan menciptakan struktur hierarki dalam sistem.
Desain top-down menjadikan keseluruhan sistem perangkat lunak sebagai satu kesatuan dan kemudian menguraikannya untuk mencapai lebih dari satu sub-sistem atau komponen berdasarkan beberapa karakteristik. Setiap sub-sistem atau komponen kemudian diperlakukan sebagai sistem dan diuraikan lebih lanjut. Proses ini terus berjalan hingga level sistem terendah dalam hierarki top-down tercapai.
Desain top-down dimulai dengan model sistem yang digeneralisasi dan terus mendefinisikan bagian yang lebih spesifik darinya. Ketika semua komponen tersusun, seluruh sistem menjadi ada.
Desain top-down lebih cocok jika solusi perangkat lunak perlu dirancang dari awal dan detail spesifik tidak diketahui.
Desain Bottom-up
Model desain bottom up dimulai dengan komponen yang paling spesifik dan dasar. Ini dilanjutkan dengan menyusun komponen tingkat yang lebih tinggi dengan menggunakan komponen tingkat dasar atau lebih rendah. Itu terus membuat komponen tingkat yang lebih tinggi sampai sistem yang diinginkan tidak berkembang sebagai satu komponen tunggal. Dengan setiap level yang lebih tinggi, jumlah abstraksi meningkat.
Strategi bottom-up lebih cocok ketika suatu sistem perlu dibuat dari beberapa sistem yang sudah ada, di mana primitif dasar dapat digunakan dalam sistem yang lebih baru.
Keduanya, pendekatan top-down dan bottom-up tidak praktis secara individual. Sebaliknya, kombinasi keduanya digunakan.