Dasar-dasar Desain Perangkat Lunak
Desain perangkat lunak adalah proses untuk mengubah persyaratan pengguna menjadi beberapa bentuk yang sesuai, yang membantu programmer dalam pengkodean dan implementasi perangkat lunak.
Untuk menilai kebutuhan pengguna, dokumen SRS (Software Requirement Specification) dibuat sedangkan untuk pengkodean dan implementasi, dibutuhkan persyaratan yang lebih spesifik dan rinci dalam istilah software. Hasil keluaran dari proses ini dapat langsung diimplementasikan ke dalam bahasa pemrograman.
Desain perangkat lunak adalah langkah pertama dalam SDLC (Software Design Life Cycle), yang memindahkan konsentrasi dari domain masalah ke domain solusi. Ini mencoba untuk menentukan bagaimana memenuhi persyaratan yang disebutkan dalam SRS.
Tingkat Desain Perangkat Lunak
Desain perangkat lunak menghasilkan tiga tingkat hasil:
- Architectural Design - Desain arsitektur adalah versi abstrak tertinggi dari sistem. Ini mengidentifikasi perangkat lunak sebagai sistem dengan banyak komponen yang berinteraksi satu sama lain. Pada level ini, desainer mendapatkan ide domain solusi yang diusulkan.
- High-level Design- Desain tingkat tinggi memecah konsep 'satu entitas-banyak komponen' dari desain arsitektur menjadi tampilan sub-sistem dan modul yang tidak terlalu abstrak dan menggambarkan interaksi mereka satu sama lain. Desain tingkat tinggi berfokus pada bagaimana sistem beserta semua komponennya dapat diimplementasikan dalam bentuk modul. Ia mengenali struktur modular dari setiap sub-sistem dan hubungan serta interaksinya satu sama lain.
- Detailed Design- Rancangan rinci berkaitan dengan bagian implementasi dari apa yang dilihat sebagai sistem dan sub-sistemnya dalam dua desain sebelumnya. Ini lebih rinci tentang modul dan implementasinya. Ini mendefinisikan struktur logis dari setiap modul dan antarmuka mereka untuk berkomunikasi dengan modul lain.
Modularisasi
Modularisasi adalah teknik untuk membagi sistem perangkat lunak menjadi beberapa modul diskrit dan independen, yang diharapkan mampu melaksanakan tugas secara mandiri. Modul-modul ini dapat bekerja sebagai konstruksi dasar untuk keseluruhan perangkat lunak. Desainer cenderung merancang modul sedemikian rupa sehingga dapat dijalankan dan / atau dikompilasi secara terpisah dan independen.
Desain modular secara tidak sengaja mengikuti kaidah strategi pemecahan masalah 'divide and conquer' hal ini dikarenakan masih banyak manfaat lain yang melekat pada desain modular suatu perangkat lunak.
Keuntungan dari modularisasi:
- Komponen yang lebih kecil lebih mudah dirawat
- Program dapat dibagi berdasarkan aspek fungsional
- Tingkat abstraksi yang diinginkan dapat dibawa ke dalam program
- Komponen dengan kohesi tinggi dapat digunakan kembali
- Eksekusi serentak dapat dilakukan
- Diinginkan dari aspek keamanan
Konkurensi
Dulu, semua perangkat lunak dimaksudkan untuk dijalankan secara berurutan. Yang kami maksud dengan eksekusi sekuensial adalah bahwa instruksi yang diberi kode akan dieksekusi satu demi satu yang menyiratkan hanya satu bagian dari program yang diaktifkan pada waktu tertentu. Katakanlah, sebuah perangkat lunak memiliki banyak modul, maka hanya satu dari semua modul yang dapat ditemukan aktif setiap saat dijalankan.
Dalam desain perangkat lunak, konkurensi diimplementasikan dengan membagi perangkat lunak menjadi beberapa unit eksekusi independen, seperti modul dan mengeksekusinya secara paralel. Dengan kata lain, konkurensi memberikan kemampuan pada perangkat lunak untuk mengeksekusi lebih dari satu bagian kode secara paralel satu sama lain.
Programer dan desainer harus mengenali modul-modul tersebut, yang dapat dibuat secara paralel.
Contoh
Fitur pemeriksa ejaan dalam pengolah kata adalah modul perangkat lunak, yang berjalan di sepanjang pengolah kata itu sendiri.
Kopling dan Kohesi
Ketika program perangkat lunak dimodularisasi, tugasnya dibagi menjadi beberapa modul berdasarkan beberapa karakteristik. Seperti yang kita ketahui, modul adalah sekumpulan instruksi yang disatukan untuk mencapai beberapa tugas. Meskipun demikian, mereka dianggap sebagai entitas tunggal tetapi dapat merujuk satu sama lain untuk bekerja sama. Ada ukuran dimana kualitas desain modul dan interaksinya di antara mereka dapat diukur. Ukuran ini disebut kopling dan kohesi.
Kohesi
Kohesi adalah ukuran yang menentukan tingkat ketergantungan intra di dalam elemen modul. Semakin besar kohesi, semakin baik desain programnya.
Ada tujuh jenis kohesi, yaitu -
- Co-incidental cohesion -Ini adalah kohesi acak dan tidak terencana, yang mungkin merupakan hasil dari pemecahan program menjadi modul yang lebih kecil demi modularisasi. Karena tidak direncanakan, ini dapat membingungkan pemrogram dan umumnya tidak diterima.
- Logical cohesion - Ketika elemen yang dikategorikan secara logis disatukan menjadi modul, itu disebut kohesi logis.
- Temporal Cohesion - Ketika elemen modul diatur sedemikian rupa sehingga diproses pada titik waktu yang sama, itu disebut kohesi temporal.
- Procedural cohesion - Ketika elemen modul dikelompokkan bersama, yang dieksekusi secara berurutan untuk melakukan suatu tugas, itu disebut kohesi prosedural.
- Communicational cohesion - Ketika elemen-elemen modul dikelompokkan bersama, yang dieksekusi secara berurutan dan bekerja pada data (informasi) yang sama, hal itu disebut kohesi komunikasi.
- Sequential cohesion - Ketika elemen-elemen modul dikelompokkan karena keluaran dari satu elemen berfungsi sebagai input bagi elemen lainnya dan seterusnya disebut kohesi sekuensial.
- Functional cohesion - Ini dianggap sebagai derajat kohesi tertinggi, dan sangat diharapkan. Elemen modul dalam kohesi fungsional dikelompokkan karena semuanya berkontribusi pada satu fungsi yang terdefinisi dengan baik. Itu juga bisa digunakan kembali.
Kopel
Coupling adalah ukuran yang menentukan tingkat ketergantungan antar modul program. Ini memberi tahu pada tingkat apa modul mengganggu dan berinteraksi satu sama lain. Semakin rendah koplingnya, semakin baik programnya.
Ada lima tingkatan kopling, yaitu -
- Content coupling - Jika modul dapat langsung mengakses atau memodifikasi atau merujuk ke konten modul lain, itu disebut penggandengan tingkat konten.
- Common coupling- Ketika beberapa modul memiliki akses baca dan tulis ke beberapa data global, itu disebut penggandengan umum atau global.
- Control coupling- Dua modul disebut gabungan kontrol jika salah satunya memutuskan fungsi modul lain atau mengubah aliran eksekusinya.
- Stamp coupling- Ketika beberapa modul berbagi struktur data umum dan bekerja pada bagian yang berbeda, itu disebut kopling stempel.
- Data coupling- Kopling data adalah ketika dua modul berinteraksi satu sama lain dengan cara melewatkan data (sebagai parameter). Jika modul melewatkan struktur data sebagai parameter, maka modul penerima harus menggunakan semua komponennya.
Idealnya, tidak ada kopling yang dianggap yang terbaik.
Verifikasi Desain
Keluaran dari proses desain perangkat lunak adalah dokumentasi desain, kode pseudo, diagram logika rinci, diagram proses, dan deskripsi rinci dari semua persyaratan fungsional atau non-fungsional.
Tahap selanjutnya, yaitu implementasi perangkat lunak, bergantung pada semua keluaran yang disebutkan di atas.
Kemudian menjadi perlu untuk memverifikasi keluaran sebelum melanjutkan ke tahap berikutnya. Lebih awal setiap kesalahan terdeteksi, semakin baik atau mungkin tidak terdeteksi sampai pengujian produk. Jika keluaran dari tahap desain dalam bentuk notasi formal, maka alat terkait untuk verifikasi harus digunakan jika tidak, tinjauan desain menyeluruh dapat digunakan untuk verifikasi dan validasi.
Dengan pendekatan verifikasi terstruktur, peninjau dapat mendeteksi kerusakan yang mungkin disebabkan oleh beberapa kondisi yang diabaikan. Tinjauan desain yang baik penting untuk desain, akurasi, dan kualitas perangkat lunak yang baik.