Implementasi Perangkat Lunak
Pada bab ini, kita akan mempelajari tentang metode pemrograman, dokumentasi dan tantangan dalam implementasi perangkat lunak.
Pemrograman Terstruktur
Dalam proses pengkodean, baris kode terus bertambah banyak, sehingga ukuran perangkat lunak bertambah. Secara bertahap, hampir mustahil untuk mengingat alur program. Jika seseorang lupa bagaimana perangkat lunak dan program, file, prosedur yang mendasarinya dibangun, maka menjadi sangat sulit untuk berbagi, men-debug, dan memodifikasi program. Solusi untuk ini adalah pemrograman terstruktur. Ini mendorong pengembang untuk menggunakan subrutin dan loop daripada menggunakan lompatan sederhana dalam kode, sehingga membawa kejelasan dalam kode dan meningkatkan efisiensinya Pemrograman terstruktur juga membantu programmer untuk mengurangi waktu pengkodean dan mengatur kode dengan benar.
Pemrograman terstruktur menyatakan bagaimana program harus diberi kode. Pemrograman terstruktur menggunakan tiga konsep utama:
Top-down analysis- Perangkat lunak selalu dibuat untuk melakukan beberapa pekerjaan rasional. Pekerjaan rasional ini dikenal sebagai masalah dalam bahasa perangkat lunak. Oleh karena itu, sangat penting bagi kami untuk memahami bagaimana menyelesaikan masalah tersebut. Di bawah analisis top-down, masalah dipecah menjadi potongan-potongan kecil yang masing-masing memiliki signifikansi. Setiap masalah diselesaikan secara individual dan langkah-langkah dengan jelas dinyatakan tentang bagaimana menyelesaikan masalah.
Modular Programming- Saat memprogram, kode dipecah menjadi kelompok instruksi yang lebih kecil. Kelompok-kelompok ini dikenal sebagai modul, subprogram atau subrutin. Pemrograman modular berdasarkan pemahaman analisis top-down. Ini mencegah lompatan menggunakan pernyataan 'goto' dalam program, yang sering membuat aliran program tidak dapat dilacak. Melompat dilarang dan format modular dianjurkan dalam pemrograman terstruktur.
Structured Coding - Mengacu pada analisis top-down, pengkodean terstruktur membagi modul menjadi beberapa unit kode yang lebih kecil dalam urutan pelaksanaannya. Pemrograman terstruktur menggunakan struktur kontrol, yang mengontrol aliran program, sedangkan pengkodean terstruktur menggunakan struktur kontrol untuk mengatur instruksinya dalam pola yang dapat ditentukan.
Pemrograman Fungsional
Pemrograman fungsional adalah gaya bahasa pemrograman yang menggunakan konsep fungsi matematika. Suatu fungsi dalam matematika harus selalu menghasilkan hasil yang sama saat menerima argumen yang sama. Dalam bahasa prosedural, aliran program berjalan melalui prosedur, yaitu pengendalian program dipindahkan ke prosedur yang disebut. Saat aliran kontrol berpindah dari satu prosedur ke prosedur lainnya, program mengubah statusnya.
Dalam pemrograman prosedural, dimungkinkan suatu prosedur untuk menghasilkan hasil yang berbeda ketika dipanggil dengan argumen yang sama, karena program itu sendiri dapat berada dalam status yang berbeda saat memanggilnya. Ini adalah properti sekaligus kelemahan pemrograman prosedural, di mana urutan atau waktu pelaksanaan prosedur menjadi penting.
Pemrograman fungsional menyediakan alat komputasi sebagai fungsi matematika, yang menghasilkan hasil terlepas dari status program. Ini memungkinkan untuk memprediksi perilaku program.
Pemrograman fungsional menggunakan konsep-konsep berikut:
First class and High-order functions - Fungsi ini memiliki kemampuan untuk menerima fungsi lain sebagai argumen atau mengembalikan fungsi lain sebagai hasil.
Pure functions - Fungsi ini tidak termasuk pembaruan yang merusak, artinya, tidak mempengaruhi I / O atau memori dan jika tidak digunakan, mereka dapat dengan mudah dihapus tanpa mengganggu program lainnya.
Recursion- Rekursi adalah teknik pemrograman di mana suatu fungsi memanggil dirinya sendiri dan mengulangi kode program di dalamnya kecuali beberapa kondisi yang ditentukan sebelumnya cocok. Rekursi adalah cara membuat loop dalam pemrograman fungsional.
Strict evaluation- Ini adalah metode mengevaluasi ekspresi yang diteruskan ke fungsi sebagai argumen. Pemrograman fungsional memiliki dua jenis metode evaluasi, ketat (bersemangat) atau non-ketat (malas). Evaluasi yang ketat selalu mengevaluasi ekspresi sebelum menjalankan fungsi. Evaluasi non-ketat tidak mengevaluasi ekspresi kecuali diperlukan.
λ-calculus- Kebanyakan bahasa pemrograman fungsional menggunakan λ-kalkulus sebagai sistem tipenya. λ-ekspresi dieksekusi dengan mengevaluasinya saat terjadi.
Lisp umum, Scala, Haskell, Erlang dan F # adalah beberapa contoh bahasa pemrograman fungsional.
Gaya pemrograman
Gaya pemrograman adalah sekumpulan aturan pengkodean yang diikuti oleh semua pemrogram untuk menulis kode. Ketika beberapa programmer mengerjakan proyek perangkat lunak yang sama, mereka sering kali perlu bekerja dengan kode program yang ditulis oleh pengembang lain. Ini menjadi membosankan atau terkadang tidak mungkin, jika semua pengembang tidak mengikuti beberapa gaya pemrograman standar untuk membuat kode program.
Gaya pemrograman yang sesuai mencakup penggunaan fungsi dan nama variabel yang relevan dengan tugas yang dimaksudkan, menggunakan lekukan yang ditempatkan dengan baik, kode komentar untuk kenyamanan pembaca dan penyajian kode secara keseluruhan. Ini membuat kode program dapat dibaca dan dimengerti oleh semua, yang pada gilirannya membuat debugging dan pemecahan kesalahan menjadi lebih mudah. Selain itu, gaya pengkodean yang tepat membantu memudahkan dokumentasi dan pembaruan.
Pedoman Coding
Praktik gaya pengkodean bervariasi dengan organisasi, sistem operasi, dan bahasa pengkodean itu sendiri.
Elemen pengkodean berikut dapat didefinisikan di bawah pedoman pengkodean organisasi:
Naming conventions - Bagian ini menjelaskan cara memberi nama fungsi, variabel, konstanta, dan variabel global.
Indenting - Ini adalah ruang yang tersisa di awal baris, biasanya 2-8 spasi atau satu tab.
Whitespace - Biasanya dihilangkan di akhir baris.
Operators- Mendefinisikan aturan penulisan matematika, tugas dan operator logika. Misalnya, operator penugasan '=' harus memiliki spasi sebelum dan sesudahnya, seperti dalam "x = 2".
Control Structures - Aturan penulisan if-then-else, case-switch, while-sampai dan untuk pernyataan aliran kontrol semata-mata dan dengan cara bersarang.
Line length and wrapping- Menentukan berapa banyak karakter yang harus ada dalam satu baris, sebagian besar baris terdiri dari 80 karakter. Pembungkusan menentukan bagaimana garis harus dibungkus, jika terlalu panjang.
Functions - Ini mendefinisikan bagaimana fungsi harus dideklarasikan dan dipanggil, dengan dan tanpa parameter.
Variables - Ini menyebutkan bagaimana variabel dari tipe data yang berbeda dideklarasikan dan didefinisikan.
Comments- Ini adalah salah satu komponen pengkodean yang penting, karena komentar yang disertakan dalam kode menggambarkan apa yang sebenarnya dilakukan oleh kode tersebut dan semua deskripsi terkait lainnya. Bagian ini juga membantu membuat dokumentasi bantuan untuk pengembang lain.
Dokumentasi Perangkat Lunak
Dokumentasi perangkat lunak merupakan bagian penting dari proses perangkat lunak. Dokumen yang ditulis dengan baik menyediakan alat dan sarana penyimpanan informasi yang hebat yang diperlukan untuk mengetahui tentang proses perangkat lunak. Dokumentasi perangkat lunak juga memberikan informasi tentang cara menggunakan produk.
Dokumentasi yang terpelihara dengan baik harus melibatkan dokumen-dokumen berikut:
Requirement documentation - Dokumentasi ini berfungsi sebagai alat utama bagi perancang perangkat lunak, pengembang, dan tim penguji untuk menjalankan tugasnya masing-masing. Dokumen ini berisi semua deskripsi fungsional, non-fungsional dan perilaku dari perangkat lunak yang dimaksud.
Sumber dokumen ini sebelumnya dapat disimpan data tentang perangkat lunak, perangkat lunak yang sudah berjalan di akhir klien, wawancara klien, kuesioner dan penelitian. Umumnya disimpan dalam bentuk spreadsheet atau dokumen pengolah kata dengan tim manajemen perangkat lunak kelas atas.
Dokumentasi ini berfungsi sebagai dasar untuk perangkat lunak yang akan dikembangkan dan banyak digunakan dalam tahap verifikasi dan validasi. Sebagian besar kasus uji dibuat langsung dari dokumentasi persyaratan.
Software Design documentation - Dokumentasi ini berisi semua informasi yang diperlukan, yang diperlukan untuk membangun perangkat lunak. Itu mengandung:(a) Arsitektur perangkat lunak tingkat tinggi, (b) Detail desain perangkat lunak, (c) Diagram aliran data, (d) Desain database
Dokumen-dokumen ini berfungsi sebagai tempat penyimpanan bagi pengembang untuk mengimplementasikan perangkat lunak. Meskipun dokumen-dokumen ini tidak memberikan rincian apapun tentang bagaimana membuat kode program, mereka memberikan semua informasi yang diperlukan untuk pengkodean dan implementasi.
Technical documentation- Dokumentasi ini dipelihara oleh pengembang dan pembuat kode sebenarnya. Dokumen-dokumen ini, secara keseluruhan, mewakili informasi tentang kode tersebut. Saat menulis kode, pemrogram juga menyebutkan tujuan kode, siapa yang menulisnya, di mana akan diperlukan, apa yang dilakukannya dan bagaimana cara melakukannya, sumber daya apa yang digunakan kode, dll.
Dokumentasi teknis meningkatkan pemahaman antara berbagai programmer yang mengerjakan kode yang sama. Ini meningkatkan kemampuan penggunaan kembali kode. Itu membuat debugging menjadi mudah dan dapat dilacak.
Ada berbagai alat otomatis yang tersedia dan beberapa dilengkapi dengan bahasa pemrograman itu sendiri. Misalnya java dilengkapi alat JavaDoc untuk menghasilkan dokumentasi teknis kode.
User documentation- Dokumentasi ini berbeda dari semua yang dijelaskan di atas. Semua dokumentasi sebelumnya disimpan untuk memberikan informasi tentang perangkat lunak dan proses pengembangannya. Tetapi dokumentasi pengguna menjelaskan bagaimana produk perangkat lunak harus bekerja dan bagaimana itu harus digunakan untuk mendapatkan hasil yang diinginkan.
Dokumentasi ini mungkin termasuk, prosedur instalasi perangkat lunak, panduan cara kerja, panduan pengguna, metode penghapusan instalasi dan referensi khusus untuk mendapatkan informasi lebih lanjut seperti pembaruan lisensi, dll.
Tantangan Implementasi Perangkat Lunak
Ada beberapa tantangan yang dihadapi oleh tim pengembang saat mengimplementasikan perangkat lunak. Beberapa di antaranya disebutkan di bawah ini:
Code-reuse- Antarmuka pemrograman bahasa saat ini sangat canggih dan dilengkapi fungsi perpustakaan yang sangat besar. Namun, untuk menurunkan biaya produk akhir, manajemen organisasi lebih memilih untuk menggunakan kembali kode, yang telah dibuat sebelumnya untuk beberapa perangkat lunak lain. Ada masalah besar yang dihadapi oleh programmer untuk pemeriksaan kompatibilitas dan memutuskan berapa banyak kode yang akan digunakan kembali.
Version Management- Setiap kali perangkat lunak baru dikeluarkan untuk pelanggan, pengembang harus memelihara dokumentasi terkait versi dan konfigurasi. Dokumentasi ini harus sangat akurat dan tersedia tepat waktu.
Target-Host- Program perangkat lunak, yang sedang dikembangkan di organisasi, perlu dirancang untuk mesin host di ujung pelanggan. Namun terkadang, tidak mungkin merancang perangkat lunak yang bekerja pada mesin target.