Aunur R. Mulyanto REKAYASA PERANGKAT LUNAK JILID 2 SMK Direktorat Pembinaan Sekolah Menengah Kejuruan Direktorat Jenderal Manajemen Pendidikan Dasar dan Menengah Departemen Pendidikan Nasional Hak Cipta pada Departemen Pendidikan Nasional Dilindungi Undang-undang REKAYASA PERANGKAT LUNAK JILID 2 Untuk SMK Penulis Utama Perancang Kulit : Aunur R. Mulyanto : Tim Ukuran Buku : 18,2 x 25,7 cm MUL r MULYANTO, Aunur R. Rekayasa Perangkat Lunak Jilid 2 untuk SMK /oleh Aunur R. Mulyanto ---- Jakarta : Direktorat Pembinaan Sekolah Menengah Kejuruan, Direktorat Jenderal Manajemen Pendidikan Dasar dan Menengah, Departemen Pendidikan Nasional, 2008. viii. 147 hlm Daftar Pustaka : A1-A2 Glosarium : B1-B6 ISBN : 978-602-8320-009-6 Diterbitkan oleh Direktorat Pembinaan Sekolah Menengah Kejuruan Direktorat Jenderal Manajemen Pendidikan Dasar dan Menengah Departemen Pendidikan Nasional Tahun 2008 KATA SAMBUTAN Puji syukur kami panjatkan kehadirat Allah SWT, berkat rahmat dan karunia Nya, Pemerintah, dalam hal ini, Direktorat Pembinaan Sekolah Menengah Kejuruan Direktorat Jenderal Manajemen Pendidikan Dasar dan Menengah Departemen Pendidikan Nasional, pada tahun 2008, telah melaksanakan penulisan pembelian hak cipta buku teks pelajaran ini dari penulis untuk disebarluaskan kepada masyarakat melalui website bagi siswa SMK. Buku teks pelajaran ini telah melalui proses penilaian oleh Badan Standar Nasional Pendidikan sebagai buku teks pelajaran untuk SMK yang memenuhi syarat kelayakan untuk digunakan dalam proses pembelajaran melalui Peraturan Menteri Pendidikan Nasional Nomor 12 tahun 2008. Kami menyampaikan penghargaan yang setinggi-tingginya kepada seluruh penulis yang telah berkenan mengalihkan hak cipta karyanya kepada Departemen Pendidikan Nasional untuk digunakan secara luas oleh para pendidik dan peserta didik SMK di seluruh Indonesia. Buku teks pelajaran yang telah dialihkan hak ciptanya kepada Departemen Pendidikan Nasional tersebut, dapat diunduh (download), digandakan, dicetak, dialihmediakan, atau difotokopi oleh masyarakat. Namun untuk penggandaan yang bersifat komersial harga penjualannya harus memenuhi ketentuan yang ditetapkan oleh Pemerintah. Dengan ditayangkannya softcopy ini akan lebih memudahkan bagi masyarakat untuk mengaksesnya sehingga peserta didik dan pendidik di seluruh Indonesia maupun sekolah Indonesia yang berada di luar negeri dapat memanfaatkan sumber belajar ini. Kami berharap, semua pihak dapat mendukung kebijakan ini. Selanjutnya, kepada para peserta didik kami ucapkan selamat belajar dan semoga dapat memanfaatkan buku ini sebaik-baiknya. Kami menyadari bahwa buku ini masih perlu ditingkatkan mutunya. Oleh karena itu, saran dan kritik sangat kami harapkan. Jakarta, Direktur Pembinaan SMK Rekayasa Perangkat Lunak i PENGANTAR PENULIS Dengan segala kerendahan hati, kami mengucapkan syukur kepada Allah SWT. Karena hanya dengan lindungan, rahmat dan karuniaNya-lah maka buku ini dapat diselesaikan. Buku yang berjudul ’Rekayasa Perangkat Lunak’ merupakan buku yang disusun untuk memenuhi kebutuhan buku pegangan bagi siswa Sekolah Menengah Kejuruan. Khususnya pada program keahlian Rekayasa Perangkat Lunak. Buku ini memuat uraian yang mengacu pada standar kompetensi dan kompetensi dasar Rekayasa Perangkat Lunak untuk siswa SMK mulai dari kelas X, XI sampai dengan kelas XII. Tiap bab berisi teori yang harus dipahami secara benar oleh peserta didik dan disertai dengan contoh-contoh soal yang relevan dengan teori tersebut. Selain itu terdapat juga soal-soal yang didasarkan pada konsep dan teori yang dibahas sebagai alat uji untuk mengukur kemampuan peserta didik dalam penguasaan materi tersebut. Dalam mengembangkan buku ini, penulis berupaya agar materi yang disajikan sesuai dengan kebutuhan kompetensi yang harus dicapai. Oleh karenanya, selain dari hasil pemikiran dan pengalaman penulis sebagai pengajar dan praktisi Rekayasa Perangkat Lunak, materi yang dikembangkan juga diperkaya dengan referensi-referensi lain yang sesuai. Pada kesempatan ini penulis ingin menyampaikan rasa terima kasih kepada semua pihak yang mendukung buku ini dapat diterbitkan. Mudahmudahan buku ini dapat bermanfaat bagi peserta didik dalam mengembangkan kemampuannya. Penulis menyadari bahwa buku ini masih perlu dikembangkan terus menerus, sehingga saran dari berbagai pihak pengguna buku ini sangat diharapkan. Malang, 2007 Penulis ii Rekayasa Perangkat Lunak Desember DAFTAR ISI KATA SAMBUTAN ..................................................................................... i PENGANTAR PENULIS ............................................................................ ii DAFTAR ISI .............................................................................................. iii PETUNJUK PENGGUNAAN BUKU ......................................................... vi BAB 1 PENDAHULUAN ............................................................................1 1.1. PENGERTIAN REKAYASA PERANGKAT LUNAK .....................2 1.2. TUJUAN REKAYASA PERANGKAT LUNAK ..............................2 1.3. RUANG LINGKUP ........................................................................3 1.4. REKAYASA PERANGKAT LUNAK DAN DISIPLIN ILMU KOMPUTER ............................................................................................4 1.5. REKAYASA PERANGKAT LUNAK DAN DISIPLIN ILMU LAIN..8 1.6. PERKEMBANGAN REKAYASA PERANGKAT LUNAK..............8 1.7. PROFESI DAN SERTIFIKASI ......................................................9 1.8. REKAYASA PERANGKAT LUNAK DAN PEMECAHAN MASALAH ..............................................................................................10 1.9. RINGKASAN...............................................................................14 1.10. SOAL-SOAL LATIHAN ...............................................................15 BAB 2 METODE REKAYASA PERANGKAT LUNAK..............................17 2.1. MODEL PROSES REKAYASA PERANGKAT LUNAK .............17 2.2. TAHAPAN REKAYASA PERANGKAT LUNAK .........................24 2.3. RINGKASAN...............................................................................31 2.4. SOAL-SOAL LATIHAN ...............................................................32 BAB 3 ELEKTRONIKA DAN SISTEM KOMPUTER ................................33 3.1. DASAR ELEKTRONIKA .............................................................34 3.2. ELEKTRONIKA DIGITAL ...........................................................36 3.3. SISTEM KOMPUTER .................................................................39 3.4. RINGKASAN...............................................................................50 3.5. SOAL-SOAL LATIHAN ...............................................................51 BAB 4 SISTEM OPERASI .......................................................................53 4.1. PENGERTIAN SISTEM OPERASI ............................................54 4.2. JENIS-JENIS SISTEM OPERASI ..............................................60 4.3. MENYIAPKAN DAN MENJALANKAN SISTEM OPERASI .......68 4.4. BEKERJA DALAM KOMPUTER JARINGAN ............................86 4.5. RINGKASAN...............................................................................92 4.6. SOAL-SOAL LATIHAN ...............................................................92 BAB 5 ALGORITMA PEMROGRAMAN DASAR .....................................93 5.1. VARIABEL, KONSTANTA DAN TIPE DATA .............................94 5.2. STRUKTUR ALGORITMA PEMROGRAMAN .........................101 5.3. PENGELOLAAN ARRAY .........................................................121 5.4. OPERASI FILE .........................................................................126 Rekayasa Perangkat Lunak iii 5.5. RINGKASAN.............................................................................128 5.6. SOAL-SOAL LATIHAN .............................................................129 BAB 6 ALGORITMA PEMROGRAMAN LANJUTAN.............................131 6.1. ARRAY MULTIDIMENSI ..........................................................132 6.2. PROSEDUR DAN FUNGSI ......................................................136 6.3. RINGKASAN.............................................................................138 6.4. SOAL-SOAL LATIHAN .............................................................139 BAB 7 PEMOGRAMAN APLIKASI DENGAN VB & VB.NET.................141 7.1. DASAR-DASAR VISUAL BASIC..............................................142 7.2. AKSES DAN MANIPULASI BASIS DATA DENGAN VISUAL BASIC ..................................................................................................163 7.3. TEKNOLOGI COM ...................................................................166 BAB 8 PEMROGRAMAN BERORIENTASI OBYEK DENGAN JAVA ...169 8.1. KONSEP PEMROGRAMAN BERORIENTASI OBYEK ..........170 8.2. PENGENALAN PADA JAVA ....................................................172 8.3. TIPE DATA, VARIABEL, DAN PERNYATAAN INPUT/OUTPUT (I/O) 176 8.4. OPERATOR..............................................................................179 8.5. STRUKTUR KONTROL PROGRAM .......................................182 8.6. EXCEPTION HANDLING .........................................................186 8.7. MULTI-THREADING ................................................................191 8.8. APLIKASI PEMROGRAMAN BERORIENTASI OBYEK DENGAN JAVA ...................................................................................194 BAB 9 PEMROGRAMAN APLIKASI DENGAN C++ .............................217 9.1. DASAR-DASAR PEMROGRAMAN C++ .................................218 9.2. FUNGSI DALAM C++ ...............................................................230 9.3. POINTER DAN ARRAY ...........................................................233 9.4. KELAS ......................................................................................240 9.5. MERANCANG APLIKASI BERORIENTASI OBYEK ...............248 BAB 10 DASAR-DASAR SISTEM BASIS DATA ...................................253 10.1. DATA, BASIS DATA DAN SISTEM MANAJEMEN BASIS DATA 254 10.2. ENTITY-RELATIONSHIP DIAGRAM .......................................262 10.3. BASIS DATA RELASIONAL ....................................................268 10.4. RINGKASAN.............................................................................277 10.5. SOAL-SOAL LATIHAN .............................................................278 BAB 11 APLIKASI BASIS DATA BERBASIS MICROSOFT ACCESS ..279 11.1. MENU-MENU UMUM APLIKASI BASIS DATA .......................280 11.2. TABEL.......................................................................................285 11.3 QUERY .....................................................................................290 11.4. FORM .......................................................................................301 11.5. REPORT ...................................................................................312 11.6. RINGKASAN.............................................................................320 iv Rekayasa Perangkat Lunak 11.7. SOAL-SOAL LATIHAN .............................................................321 BAB 12 BASIS DATA BERBASIS SQL .................................................323 12.1. SEKILAS TENTANG SQL ........................................................324 12.2. MEMPERSIAPKAN PERANGKAT LUNAK BERBASIS SQL..325 12.3. MENU / FITUR UTAMA ............................................................328 12.4. PEMBUATAN DAN PENGISIAN TABEL .................................329 12.5. OPERASI PADA TABEL DAN VIEW .......................................332 12.6. MENGGUNAKAN T-SQL .........................................................339 12.7. FUNGSI, PROCEDURE DAN TRIGGER ................................349 12.9. RINGKASAN.............................................................................357 12.10. SOAL-SOAL LATIHAN .............................................................358 BAB 13 DESAIN WEB STATIS DAN HTML ..........................................359 13.1. KONSEP DASAR DAN TEKNOLOGI WEB .............................360 13.2. PERSIAPAN PEMBUATAN WEB ............................................362 13.3. MEMBUAT DAN MENGUJI HALAMAN WEB .........................367 13.4. HTML ........................................................................................369 13.5. RINGKASAN.............................................................................387 13.6. SOAL-SOAL LATIHAN .............................................................387 BAB 14 DINAMIS BERBASIS JSP ........................................................389 14.1 DASAR WEB DINAMIS ............................................................390 14.2 RINGKASAN.............................................................................413 14.3 SOAL-SOAL LATIHAN .............................................................414 LAMPIRAN A DAFTAR PUSTAKA LAMPIRAN B GLOSARIUM, DAFTAR WEBSITE LAMPIRAN C DAFTAR GAMBAR, DAFTAR TABEL Rekayasa Perangkat Lunak v PETUNJUK PENGGUNAAN BUKU A. Deskripsi Umum Buku ini diberi judul “Rekayasa Perangkat Lunak”,sama dengan salah satu program keahlian pada Sekolah Menengah Kejuruan (SMK). Meskipun demikian, sebenarnya isi dari buku ini tidak secara khusus membahas tentang Rekayasa Perangkat Lunak. Dari sisi pandang bidang Ilmu Komputer ada lima sub-bidang yang tercakup dalam dalam buku ini, yaitu sub-bidang Rekayasa Perangkat Lunak, Sistem Operasi, Algoritma dan Struktur Data, Bahasa Pemrograman dan Basis Data. Hal ini disesuaikan dengan kurikulum tingkat SMK untuk Program Keahlian Rekayasa Perangkat Lunak. Pokok bahasan tentang Rekayasa Perangkat Lunak secara umum membahas dasar-dasar pengertian Rekayasa Perangkat Lunak, masalah dan pemecahan masalah, dan metode-metode pengembangan perangkat lunak. Pembahasan tentang sub-bidang Sistem Operasi berisi sistem computer, sistem operasi dan bekerja dalam jaringan computer. Cakupan materi algoritma meliputi algoritma dasar dan algoritma lanjutan. Sub bidang Bahasa Pemrograman mengambil porsi yang cukup besar, meliputi pemrograman GUI dengan VB & VB.Net, pemrograman Java, pemrograman C++, pemrograman berorientasi obyek dan Pemrograman berbasis web. Sub-bidang terakhir yang menjadi bagian dari buku ini adalah Basis Data dengan cakupan tentang system basis data, pemodelan konseptual, basis data relasional, Microsoft Access dan SQL. B. Peta Kompetensi Secara umum, buku ini mengacu pada Standar Kompetensi dan Kompetensi Dasar (SKKD) bagi SMK seperti berikut. 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. vi Menggunakan algoritma pemrograman tingkat dasar Menggunakan algoritma pemrograman tingkat lanjut Mengoperasikan aplikasi basis data Membuat aplikasi berbasis Microsoft Access Menguasai teknik elektronika dasar Menguasai teknik elektronika digital Membuat file dengan HTML sesuai spesifikasi Menerapkan dasar-dasar pembuatan web statis tingkat dasar Membuat program aplikasi menggunakan VB dan VB.NET Membuat paket software aplikasi Melakukan pemrograman data deskripsi (SQL – Stuctured Query Language) tingkat dasar Mengoperasikan bahasa pemrograman data deskripsi (SQL) tingkat lanjut Membuat halaman web dinamis tingkat dasar Membuat halaman web dinamis tingkat lanjut Membuat program aplikasi web menggunakan JSP Rekayasa Perangkat Lunak 16. 17. 18. 19. 20. 21. 22. 23. Membuat program aplikasi basis data menggunakan XML Membuat program basis data menggunakan Microsoft (SQL Server) Membuat program basis data menggunakan PL/SQL (Oracle) Membuat program aplikasi menggunakan C++ Menjelaskan sistem peripheral Membuat program dalam bahasa pemrograman berorientasi obyek Membuat program aplikasi menggunakan Java Mengoperasikan sistem operasi komputer berbasis teks dan GUI Dalam penyajian buku ini, bab-bab tidak disusun berdasarkan SKKD, akan tetapi disusun berdasarkan urutan materi pokok bahasan. Sehingga di beberapa bab berisi gabungan dari beberapa standar kompetensi. Atau satu kompetensi dasar mungkin berada tidak pada kelompok standar kompetensi seperti pada daftar SKKD, tetapi berada pada sub bab yang lain. Kesesuaian SKKD dan isi bab dapat dilihat pada table berikut ini. Kode Kompetensi ELKA-MR.UM.001.A ELKA.MR.UM.004.A TIK.PR02.001.01 TIK.PR02.002.01 HDW.OPR.103.(1).A HDW.OPR.104.(1).A TIK.PR02.020.01 TIK.PR08.004.01 TIK.PR08.024.01 TIK.PR08.027.01 TIK.PR08.003.01 TIK.PR02.016.01 TIK.PR03.001.01 TIK.PR03.002.01 TIK.PR04.002.01 TIK.PR04.003.01 Kompetensi Bab Terkait 3 3 Menguasai Teknik Dasar Elektronika Menguasai Dasar Elektronika Digital dan Komputer Menggunakan algoritma pemograman 5 tingkat dasar Menggunakan algoritma pemograman 6 tingkat lanjut Mengoperasikan sistem operasi jaringan 4 komputer berbasis teks Mengoperasikan sistem operasi jaringan 4 komputer berbasis GUI Mengoperasikan aplikasi basis Data 10 dan 11 Membuat aplikasi Berbasis Microsoft Acces 11 Membuat dokumen dengan HTML sesuai 13 spesifikasi Menerapkan dasar-dasar pembuatan web 13 statis tingkat dasar. Membuat program aplikasi menggunakan 7 VB & VB.NET Membuat paket software Aplikasi 7 Mengoperasikan bahasa pemrograman 12 data deskripsi (SQL) tingkat dasar Mengoperasikan bahasa pemrograman 12 data deskripsi (SQL) tingkat Lanjut Membuat Halaman Web dinamis tingkat 13 dasar Membuat Halaman Web dinamis tingkat 13 Lanjut. Rekayasa Perangkat Lunak vii Kode Kompetensi TIK.PR02.009.01 TIK.PR08.012.01 TIK.PR08.001.01 TIK.PR06.003.01 TIK.PR08.005.01 TIK.PR08.006.01 TIK.PR08.008.01 Kompetensi Mengoperasikan bahasa pemograman berorientasi obyek Membuat program aplikasi menggunakan Java Membuat program aplikasi menggunakan C++ Menjelaskan sistem Peripheral Membuat program basis data menggunakan PL/SQL Membuat program basis data menggunakan SQL Server Membuat program aplikasi web berbasis JSP Bab Terkait 8 8 9 3 10 dan 12 12 14 C. Cara Menggunakan Buku Buku ini secara khusus ditujukan kepada siswa dan guru SMK untuk program keahlian RPL. Namun demikian, buku ini juga terbuka bagi pembaca umum yang berminat dalam dunia RPL, Algoritma dan Pemrograman, Basis Data dan Internet. Bagi siswa, buku ini dapat dijadikan buku pegangan, karena ini buku ini menyediakan bahan-bahan pelajaran yang cukup lengkap untuk mata pelajaran selama tiga tahun di bangku sekolah. Beberapa bagian dari buku ini mungkin memerlukan buku-buku bantu lainnya untuk lebih memperkaya wawasan dan peningkatan kemampuan. Sedangkan bagi guru, buku ini dapat digunakan sebagai buku referensi untuk menyusun modul-modul ajar bagi anak didiknya. Buku ini disusun sedemikian rupa agar siswa dapat belajar secara mandiri dan terdorong untuk mencoba secara langsung. Oleh karena itu dalam buku ini, akan banyak dijumpai ilustrasi baik yang berupa gambar, skema maupun listing program. Hal ini dimaksudkan agar siswa dapat dengan mudah memahami penjelasan ataupun penerapan suatu konsep tertentu. Bahkan pada bagian akhir bab diakhiri dengan soal-soal latihan dari pokok bahasan pada bab tersebut. viii Rekayasa Perangkat Lunak BAB 6 ALGORITMA PEMROGRAMAN LANJUTAN Gambar 6.1. di samping ini saya yakin kalian pernah melihatnya. Ya, inilah notasi umum dari salah satu teori matematika, yaitu matrik. Operasi matrik, merupakan operasi yang banyak digunakan dalam banyak aktifitas yang membutuhkan perhitungan dengan model banyak bilangan. Cobalah buka kembali Gambar 6.1. Notasi matrik. buku matematika kalian yang membahas matrik kalian akan melihat banyak sekali yang bisa kita lakukan dengan matrik. Pernahkan kalian mendengar perangkat lunak bernama MATLAB? Perangkat lunak yang didasarkan pada operasi matrik ini sangat populer dikalangan ilmuan, insinyur dan orang-orang yang banyak berkecimpung dengan perhitungan. Dengan menggunakan array kalian juga bisa membuat program yang dapat melakukan operasi matrik seperti halnya MATLAB. Standar kompetensi algoritma pemrograman lanjutan terdiri atas empat kompetensi dasar yaitu, menggunakan array multidimensi dan menggunakan prosedur dan fungsi. Dalam penyajian pada buku ini, setiap kompetensi dasar memuat uraian materi, dan latihan. Ringkasan diletakkan pada setiap akhir bab. Sebelum mempelajari kompetensi ini ingatlah kembali prinsip pemecahan masalah, algoritma pemrograman dasar dan materi-materi pendukung dari mata pelajaran matematika. Pada akhir bab, tercantum soal-soal latihan yang disusun dari soal-soal yang mudah hingga soal-soal yang sulit. Latihan soal ini digunakan untuk mengukur kemampuan terhadap kompetensi dasar ini. Artinya setelah mempelajari kompetensi dasar ini secara mandiri dengan bimbingan guru sebagai fasilitator, ukurlah sendiri kemampuan dengan mengerjakan soal-soal latihan tersebut. Rekayasa Perangkat Lunak 131 TUJUAN Setelah mempelajari bab ini diharapkan kalian akan mampu : o Menggunakan array multidimensi o Menggunakan prosedur dan fungsi 6.1. ARRAY MULTIDIMENSI 6.1.1. Pengertian Array Multidimensi Array satu dimensi seperti pada Bab 5 sangat baik untuk menyimpan data sejenis yang berurutan, namun bagaimana bila kita ingin menyimpan daftar kota dengan temperature rata-ratanya secara bersama-sama, atau menyimpan data nama Siswa dengan nilai ujiannya? Pada kasus seperti ini kita dapat menggunakan dua array satu dimensi, satu array untuk menyimpan nama dan satu array untuk menyimpan nilai. Namun ini bukanlah pilihan yang baik karena akan menyulitkan dan membuat kode program menjadi tidak efisien. Pilihan yang lebih baik adalah dengan menggunakan pendekatan Array Multidimensi. Kita dapat menyimpan dengan menggunakan array dua dimensi untuk kasus di atas. Perhatikan gambar berikut ini untuk melihat perbedaan dua array satu dimensi dengan array dua dimensi. Nama(4) Nilai(4) Joni 70 Rudi 80 Sari 45 Dono 56 Indro 77 Dua array satu dimensi 0 1 2 3 4 NilaiSiswa (4,1) Joni 70 Rudi 80 Sari 45 Dono 56 Indro 77 Array dua dimensi Gambar 6.2. Perbedaan array satu dimensi dan dua dimensi Array dua dimensi mempunyai dua indeks. Indeks yang pertama menunjukkan baris sedangkan indeks yang kedua adalah kolom. Pada Gambar 6.2, variable array NilaiSiswa memiliki dua indeks yaitu indeks pertama 4 yang menyatakan nilai indeks maksimal untuk baris adalah 4 (atau ada 5 baris karena indeks baris pertama bernilai 0), sedangkan indeks kedua adalah 1 yang menunjukkan nilai indeks maksimal untuk kolom adalah 1 (atau ada 2 kolom karena indeks kolom pertama bernilai 0). Untuk mendeklarasikan array dua dimensi dapat digunakan cara sebagai berikut : Dim NilaiSiswa(4,1) Sedangkan untuk mengakses nilai pada array dua dimensi dapat digunakan sepeti contoh berikut. Contoh 6.1. Membaca nilai array multidimensi 132 Rekayasa Perangkat Lunak Print NilaiSiswa(3,0) Print NilaiSiswa(3,1) Pernyataan pertama dari contoh 6.1, akan menghasilkan output “Dono” (Baris ke 4 dan kolom pertama) sedangkan pernyataan kedua menghasilkan output 56 (Baris ke 4 kolom kedua). Keuntungan menggunakan array multidimensi adalah secara konseptual, array ini lebih mudah dikelola. Sebagai contoh kita ingin membuat program permainan dan kita ingin mencari posisi dari suatu tempat pada sebuah papan permainan. Setiap bujursangkar dapat diidentifikasi dengan menggunakan dua angka, yaitu koordinat horizontal dan vertikalnya (atau baris dan kolomnya). Struktur seperti ini adalah tipikal penggunaan array dua dimensi. Koordinat horizontal adalah indeks barisnya sedangkan koordinat vertical adalah indeks kolomnya. Bentuk array multidimensi ini dapat dikembangkan menjadi lebih dari dua dimensi. Pernyataan Dim Matrix(9,9,9) akan membuat array multidimensi yang memiliki 1000 elemen (10x10x10). 6.1.2. Operasi Matriks dengan Array Multidimensi Seperti disinggung di awal bab ini, kita bisa menggunakan array untuk melakukan operasi matrik. Perhatikan Gambar 6.3 berikut ini. Gambar 6.3 ini menunjukkan matrik dua dimensi yang terdiri dari 4 baris dan 3 kolom. Atau biasa dinotasikan sebagai A4x3. Hal ini identik dengan array multidimensi dengan yang kita definisikan sebagai A(3, 2). Perhatikan kembali angka pada indeks array selalu lebih kecil satu dari jumlah sesungguhnya karena Gambar 6.3. Matrik 4 x 3. indeks selalu dimulai dengan 0. Sedangkan indeks pada matrik dimulai pada angka 1. Untuk membuat array atau matrik seperti pada Gambar 6.3, maka kita memerlukan struktur pengulangan. Bentuk for dapat kita gunakan karena kita telah tahu dengan pasti berapa baris dan berapa kolomnya. Gambar berikut menyajikan flowchart untuk membuat matrik pada Gambar 6.3. Pada Gambar 6.4. kita melihat dua buah variabel counter yaitu I dan J. I digunakan untuk membuat indeks pada baris yaitu 4 baris (1 to 4), sedangkan J digunakan untuk membuat indeks pada kolom yaitu 3 kolom (1 to 3). Pembacaan data akan berlangsung sebagai berikut: A(1,1) A(1,2) A(1,3) A(2,1) A(2,2) A(2,3) = = = = = = .... .... .... .... .... .... dan seterusnya. Rekayasa Perangkat Lunak 133 Gambar 6.4. Algoritma untuk membuat matrik 4 x 3. Contoh 6.2. Operasi penjumlahan pada matrik. Perhatikan matrik berikut ini: Operasi matriks di atas adalah operasi penjumlahan dua buah matrik dengan dimensi yang sama yaitu 3x3. Bagaimanakah algoritma penyelesaiannya? Penyelesaian: Pada contoh soal di atas ada dua buah matriks misalkan A matriks pertama dan B adalah matriks kedua. Selain itu juga dibutuhkan matrik ke tiga yaitu C sebagai hasil penjumlahan matriks A dan B. Gambar 6.5. menunjukkan algoritma penjumlahan dua buah matriks. 134 Rekayasa Perangkat Lunak Gambar 6.5. Algoritma penjumlahan dua buah matrik Rekayasa Perangkat Lunak 135 6.2. PROSEDUR DAN FUNGSI Setiap bahasa pemrograman selalu menyediakan fungsi-fungsi yang sudah didefinisikan oleh bahasa pemrograman tersebut (built-in function). Namun ada kalanya kita memerlukan suatu prosedur tertentu yang kita gunakan berulang kali dan tidak tersedia dalam built-in function. Prosedur adalah sekumpulan perintah yang merupakan bagian dari program yang lebih besar yang berfungsi mengerjakan suatu tugas tertentu. Prosedur atau kadang disebut subrutin / subprogram biasanya relative independent terhadap bagian kode program yang lain. Atau sebenarnya prosedur dapat berdiri sendiri. Keuntungan menggunakan prosedur adalah : o mengurangi duplikasi kode program. o memberikan kemungkinan penggunaan kembali kode untuk program yang lain. o memecah masalah yang rumit dalam masalah-masalah yang lebih kecil dan lebih mudah diselesaikan (lihat prinsip problem reduction pada Bab 2). o membuat kode program lebih mudah dibaca. o dapat digunakan untuk menyembunyikan detil program. Pada flowchart untuk menuliskan prosedur digunakan notasi Predefined Process (lihat Bab 5 untuk notasi flowchart). Secara skematis penggunaan prosedur dapat dilihat pada Gambar 6.6. Gambar 6.6. Skema penggunaan prosedur. Gambar 6.6. menunjukkan ada proses utama yang terjadi dan ada prosedur yang sebenarnya merupakan bagian dari proses utama ini. Ketika proses utama membutuhkan suatu tugas tertentu maka proses utama akan memanggil prosedur tertentu menyelesaikan tugas tersebut. Perhatikan contoh berikut: 136 Rekayasa Perangkat Lunak Contoh 6.3. Prosedur Buatlah algoritma menghitung luas segitiga, segiempat, dan lingkaran. Penyelesaian: Untuk membuat algoritma ini kita dapat memandang proses perhitungan luas segitiga, luas segiempat dan luas lingkaran sebagai bagian program yang berdiri sendiri. Kita dapat membuat prosedur untuk masing-masing proses. Dan kita akan memanggil prosedur tersebut dari proses utama (Gambar 6.7). Gambar 6.7. Penyelesaian contoh 6.3. Urutan proses pada Gambar 6.7 adalah sebagai berikut. o Pembacaan data o Pada proses utama akan terjadi pengecekan pada data yang dibaca, o Apabila data yang dibaca adalah untuk segitiga, maka proses utama akan memanggil prosedur hitung luas segitiga dengan Rekayasa Perangkat Lunak 137 membawa nilai variable yang diperlukan oleh prosedur luas hitung segitga. o Proses perhitungan luas segitiga hanya dilakukan pada prosedur tersebut. o Setelah proses perhitungan maka hasil perhitungan akan dibawa kembali ke proses utama untuk dicetak hasilnya. Urutan proses yang sama juga terjadi jika data yang dibaca adalah untuk segiempat atau lingkaran. Prosedur yang baik memiliki ciri-ciri sebagai berikut : o Hanya memiliki satu fungsi tujuan (logical inherent). Sebuah prosedur sebaiknya hanya memiliki satu fungsi tujuan dan tidak bercampur dengan tujuan-tujuan lain. Hal ini untuk membuat prosedur lebih focus sehingga tujuan akan dapat tercapai dengan baik. o Tidak tergantung pada prosedur lain (independent). Sebuah prosedur harusnya bersifat mandiri, artinya prosedur ini dapat berjalan dan diuji tanpa menunggu bagian lainnya selesai. Selain itu variable-variabel yang digunakan dalam prosedur tersebut tidak mempengaruhi variable-variabel yang digunakan pada bagian lain di keseluruhan program. o Berukuran kecil (small size). Yang dimaksud ukuran disini adalah panjang algoritma atau panjang kode program pada suatu prosedur. Ukuran kecil akan mudah dibaca dan diperbaiki. Apabila sebuah modul sudah terlalu besar maka sebaiknya dipertimbangkan untuk dipecah-pecah menjadi beberapa modul yang lebih kecil. 6.3. 138 Ringkasan • Array dua dimensi mempunyai dua indeks. Indeks yang pertama menunjukkan baris sedangkan indeks yang kedua adalah kolom. • Pembacaan data dan penulisan data pada array multidimensi dilakukan dengan langsung menunjuk pada nomor indeksnya • Prosedur adalah sekumpulan perintah yang merupakan bagian dari program yang lebih besar yang berfungsi mengerjakan suatu tugas tertentu. Rekayasa Perangkat Lunak 6.4. Soal-Soal Latihan 1. Perhatikan contoh 6.1 di atas. pengurangan dua buah matriks. Buatlah algoritma untuk operasi 2. Buatlah juga algoritma untuk operasi perkalian dua buah matriks. 3. Dengan menggunakan prosedur buatlah sebuah algoritma yang membaca data matrik kemudian memilih melakukan operasi penjumlahan, pengurangan dan perkalian dua buah matrik. Rekayasa Perangkat Lunak 139 140 Rekayasa Perangkat Lunak BAB 7 PEMOGRAMAN APLIKASI DENGAN VB & VB.NET Gambar 7.1. Aplikasi yang dibangun dengan Visual Basic. Perhatikan Gambar 7.1. di atas. Tampilan pada gambar tersebut menunjukkan sebuah aplikasi yang menampilkan sekumpulan data pada tabel. Suatu ketika kalian akan menjumpai aplikasi yang serupa. Aplikasi di atas dapat dibangun dengan menggunakan Visual Basic secara cepat, tanpa harus dipusingkan dengan masalah pembuatan tabel, menu, tombol atau yang lainnya. Tinggal klik, seret, letakkan, atur posisi kemudian buat kodenya, aplikasi sudah langsung bisa dijalankan. Standar kompetensi pemrograman dengan VB dan VB.Net dasar terdiri atas tiga kompetensi dasar. Dalam penyajian pada buku ini, setiap kompetensi dasar memuat uraian materi, dan latihan. Ringkasan diletakkan pada setiap akhir bab kemudian dilanjutkan dengan soal-soal latihan. Kompetensi dasar pada bab ini adalah menjelaskan dasar-dasar Visual Basic, mengakses dan memanipulasi data dengan Visual Basic, dan menerapkan teknologi COM. Sebelum mempelajari kompetensi ini ingatlah kembali sistem operasi, prinsip pemecahan masalah, algoritma pemrograman dasar dan lanjutan dan materi-materi pendukung dari mata pelajaran matematika. Rekayasa Perangkat Lunak 141 TUJUAN Setelah mempelajari bab ini diharapkan pembaca akan mampu : o Menjelaskan dasar-dasar Visual Basic o Mengakses dan memanipulasi data dengan Visual Basic o Menerapkan teknologi COM 7.1. Dasar-dasar Visual Basic Visual Basic (VB) adalah salah satu bahasa pemrograman komputer. Bahasa pemrograman VB, yang dikembangkan oleh Microsoft sejak tahun 1991, merupakan pengembangan dari pendahulunya yaitu bahasa pemrograman BASIC (Beginner’s All-purpose Symbolic Instruction Code) yang dikembangkan pada era 1950-an. VB adalah salah suatu developement tools untuk membangun aplikasi dalam lingkungan Windows. Dalam pengembangan aplikasi, Visual Basic menggunakan pendekatan Visual untuk merancang user interface dalam bentuk form, sedangkan untuk codingnya menggunakan dialek bahasa Basic yang cenderung mudah dipelajari. Visual Basic telah menjadi tools yang terkenal bagi para pemula maupun para developer. Namun ada kelemahan dari VB yaitu pada kinerja yang relative terasa lebih lambat dibanding dengan bahasa pemrograman lain. Namun dengan perkembangan processor dan main memory yang semakin cepat permasalahan ini menjadi tidak begitu penting. Visual Basic adalah perangkat lunak yang berjalan di atas platform sistem operasi Microsoft Windows. Untuk memulai Visual Basic dapat dilakukan dengan mengklik Start -> Programs -> Microsoft Visual Studio 6 -> Microsoft Visual Basic. Tampilan awal Visual Basic akan tampak seperti Gambar 7.2. Gambar 7.2. Tampilan awal Visual Basic. 142 Rekayasa Perangkat Lunak Pada Gambar 7.2 kita diminta untuk memilih jenis proyek yang akan kita buat. Untuk tahap awal proyek Standar.EXE merupakan pilihan yang biasa dilakukan. Setelah kita memilih Standar.EXE maka kita akan dibawa pada tampilan berikut. Gambar 7.3. Tampilan awal untuk pilihan Standard.EXE. Sebelum kita bekerja dengan Visual Basic, maka ada baiknya kita mengenali lebih dulur lingkungan kerja (IDE) Visual Basic. IDE (Integrated Developement Environment) Visual Basic merupakan Lingkungan Pengembangan Terpadu bagi programmer dalam mengembangkan aplikasinya. Dengan menggunakan IDE programmer dapat membuat user interface, melakukan coding, melakukan testing dan debuging serta menkompilasi program menjadi executable. Penguasaan yang baik akan IDE akan sangat membantu programmer dalam mengefektifkan tugas-tugasnya sehingga dapat bekerja dengan efisien. Tampilan IDE VB dapat dilihat pada Gambar 7.4. Rekayasa Perangkat Lunak 143 Gambar 7.4. IDE Visual Basic • • • Menu Bar, digunakan untuk memilih menyimpan project, membuka project, dll tugas-tugas tertentu seperti Main Toolbar, digunakan untuk melakukan tugas-tugas tertentu dengan cepat. Jendela Project, jendela ini berisi gambaran dari semua modul yang terdapat dalam aplikasi anda. Anda dapat menggunakan icon Toggle Folders untuk menampilkan modul-modul dalam jendela tersebut secara di group atau berurut berdasarkan nama. Anda dapat menggunakan Ctrl+R untuk menampilkan jendela project, ataupun menggunakan icon Project Explorer. • Jendela Form Designer, jendela ini merupakan tempat anda untuk merancang user interface dari aplikasi anda. Jadi jendela ini menyerupai kanvas bagi seorang pelukis. • Jendela Toolbox, jendela ini berisi komponen-komponen yang dapat anda gunakan untuk mengembangkan user interface. 144 Rekayasa Perangkat Lunak • Jendela Code, merupakan tempat bagi anda untuk menulis kode. Anda • Jendela Properties, merupakan daftar properti-properti object yang sedang • Jendela Color Palette, adalah fasilitas cepat untuk mengubah warna suatu object. • Jendela Form Layout, akan menunjukan bagaimana form bersangkutan ditampilkan ketika run-time. dapat menampilkan jendela ini dengan menggunakan kombinasi Shift-F7. terpilih. Sebagai contohnya anda dapat mengubah warna tulisan (foreground) dan warna latarbelakang (background). Anda dapat menggunakan F4 untuk menampilkan jendela properti. Jendela Toolbox merupakan jendela yang sangat penting bagi anda. Dari jendela ini anda dapat mengambil komponen-komponen (object) yang akan ditanamkan pada form untuk membentuk user interface. • Pointer bukan merupakan suatu kontrol; gunakan icon ini ketika anda ingin memilih kontrol yang sudah berada pada form. • PictureBox adalah kontrol yang digunakan untuk menampilkan image dengan format: BMP, DIB (bitmap), ICO (icon), CUR (cursor), WMF (metafile), EMF (enhanced metafile), GIF, dan JPEG. Gambar 7.5. Toolbox VB 6. • Label • TextBox adalah kontrol yang mengandung string yang dapat diperbaiki oleh pemakai, dapat berupa satu baris tunggal, atau banyak baris. • Frame adalah kontrol yang digunakan sebagai kontainer bagi kontrol lainnya. • CommandButton adalah kontrol yang digunakan untuk menampilkan teks yang tidak dapat diperbaiki oleh pemakai. merupakan kontrol hampir ditemukan pada setiap form, dan digunakan untuk membangkitkan event proses tertentu ketika pemakai melakukan klik padanya. Rekayasa Perangkat Lunak 145 • CheckBox digunakan untuk pilihan yang isinya bernilai yes/no, true/false. • OptionButton sering digunakan lebih dari satu sebagai pilihan terhadap • ListBox mengandung sejumlah item, dan user dapat memilih lebih dari satu (bergantung pada property MultiSelect). • ComboBox merupakan konbinasi dari TextBox dan suatu ListBox dimana pemasukkan data dapat dilakukan dengan pengetikkan maupun pemilihan. • beberapa option yang hanya dapat dipilih satu. HScrollBar dan VScrollBar digunakan untuk membentuk scrollbar berdiri sendiri. • Timer digunakan untuk proses background yang diaktifkan berdasarkan interval waktu tertentu. Merupakan kontrol non-visual. • DriveListBox, DirListBox, dan FileListBox sering digunakan untuk membentuk dialog box yang berkaitan dengan file. • Shape dan Line digunakan untuk menampilkan bentuk seperti garis, persegi, bulatan, oval. • Image berfungsi menyerupai image box, tetapi tidak dapat digunakan • Data digunakan untuk data binding • OLE dapat digunakan sebagai tempat bagi program eksternal seperti Microsoft Excel, Word, dll. sebagai kontainer bagi kontrol lainnya. Sesuatu yang perlu diketahui bahwa kontrol image menggunakan resource yang lebih kecil dibandingkan dengan PictureBox 7.1.1. Prinsip Pokok Pemrograman Berbasis GUI Secara prinsip ada dua bagian pokok dalam pengembangan aplikasi dengan menggunakan VB, yaitu: visual design dan event-driven programming. Visual Design Dalam lingkungan Windows, User-interface sangat memegang peranan penting, karena dalam pemakaian aplikasi yang kita buat, pemakai senantiasa berinteraksi dengan User-interface tanpa menyadari bahwa dibelakangnya berjalan instruksi-instruksi program yang mendukung tampilan dan proses yang dilakukan. Pada pemrograman Visual, pengembangan aplikasi selalu dimulai Untuk mendisain user interface, dengan pembentukkan user interface. pengetahuan yang paling dibutuhkan hanyalah pemahaman dasar tentang jenis dan kegunaan dari control dan dasar-dasar bagaimana menggambar sebuah object. Form dan control merupakan elemen-elemen dasar dalam user interface pada aplikasi-aplikasi berbasis Windows. Dalam VB, elemen-elemen ini disebut obyek karena dapat dimanipulasi seperti sebuah obyek. Obyek merupakan 146 Rekayasa Perangkat Lunak suatu kombinasi dari kode dan data yang dapat diperlakukan sebagai satu kesatuan. Sebuah obyek memiliki sejumlah property dan sejumlah method, dan akan bereaksi terhadap sejumlah event eksternal seperti halnya obyek fisik. Sebagai ilustrasi (gambar 7.6), sebuah mobil adalah sebuah obyek fisik yang memiliki property, method dan event. Salah satu property adalah warna. Biasanya property warna dari mobil ditetapkan ketika sebuah mobil dibuat. Tetapi kalau kita tidak suka dengan warna mobil yang kita beli, kita masih dapat merubahnya, misalnya dengan mengecat ulang. Demikian juga dalam VB, property dari sebuah control biasanya ditentukan ketika object dibuat (pada saat ditempatkan pada sebuah form), tetapi kita dapat merubah property ini dengan memberikan nilai baru. Kita dapat merubah nilai property pada saat disain (dengan menggunakan jendela Properties) atau pada saat runtime (melalui kode program). Beberapa property hanya tersedia pada saat disain, dan beberapa property hanya tersedia pada saat runtime. Gambar 7.6. Obyek, Property, Method dan Event Event-Driven Programming Pemrograman suatu aplikasi bukanlah sesuatu yang mudah, namun ada sebuah metodologi yang tidak boleh kita tinggalkan. Aplikasi yang dibuat dengan VB bukanlah sebuah program yang monolithic (hanya ada satu urutan jalannya program aplikasi). Ketika kita membuat program dengan VB, pertama kita harus menentukan bagaimana aplikasi akan berinteraksi dengan pengguna. Rekayasa Perangkat Lunak 147 Atau dengan kata lain, kita harus menentukan bagaimana setiap control bereaksi terhadap aksi yang dilakukan pengguna (misalnya: click mouse, double-click mouse, penekanan salah satu tombol pada keyboard, dan lainlain). Konsep ini biasa disebut sebagai Event-Driven Programming, karena bukan aplikasi yang menentukan alur namun kejadian (event) yang disebabkan oleh pengguna yang menentukan alur dari aplikasi. Program aplikasi yang kita buat bereaksi terhadap kondisi eksternal (event), dan aksi dari pengguna yang menentukan bagaimana alur dari aplikasi. 7.1.2. Tipe Data, Variabel dan Konstanta Secara umum tipe data, variabel dan konstanta dalam Visual Basic tidak banyak berbeda dengan apa yang disampaikan pada Bab 5. Coba buka kembali Bab tersebut untuk mengingat kembali bagian ini. Yang berbeda adalah bentuk pendeklarasian variabel dan konstanta. Perhatikan contoh berikut. Contoh 7.1. Contoh pendeklarasian variabel, konstanta dan tipe data. Dim speed As Double Dim timeElapsed As Double Dim NumberStudent as Integer = 10 Dim velocity as Single Dim Nama as String Const phi as Single = 3.14 Pada contoh 7.1 kita bisa mendeklarasikan variabel dengan kata kunci Dim sedangkan untuk konstanta menggunakan kata kunci Const. Kita juga bisa langsung mengisikan nilai awal setelah definisi tipe data dari suatu variabel. Salah satu keuntungan menggunakan pemrograman berbasis GUI seperti Visual Basic adalah tersedianya obyek-obyek yang dapat diperlakukan sebagai tipe data. Perhatikan contoh berikut ini. Contoh 7.2. Contoh penggunaan tipe data obyek. Dim Dim Dim Dim Dim Dim Dim frm As Form midfrm As MDIForm ctrl As Control obj As Object inv As frmInvoice txtSalary As TextBox wrk As Excel.Worksheet Pada contoh 7.2 di atas, pernyataan Form, MDIForm, Control dan Object adalah kontrol-kontrol yang dimiliki oleh Visual Basic. Sedangkan frmInvoice adalah form yang telah kita beri nama frmInvoice. Visual Basic juga memungkinkan kita untuk menggunakan obyek dari luar Visual Basic. Perhatikan pada baris terakhir di atas. Kita menggunakan worksheet dari Excel untuk kita gunakan dalam program kita. 148 Rekayasa Perangkat Lunak 7.1.3. Operator Operator adalah simbol yang digunakan dalam bahasa pemrograman untuk melakukan suatu operasi terhadap nilai data. Simbol operator bisa berupa karakter ataupun kata khusus. Pada Visual Basic ada tiga kelompok operator utama, yaitu operator aritmatika, operator perbandingan dan operator logika. • Operator aritmatika Operator aritmatika digunakan untuk operasi matematis terhadap nilai data. Notasi-notasi yang digunakan tampak pada tabel berikut ini : Tabel 7.1. Operator Aritmatika. Notasi/simbol untuk operator ini memiliki hirarki kekuatan, artinya apabila ada dua atau lebih operator digunakan bersama-sama, maka operator dengan hirarki yang lebih tinggi akan dieksekusi lebih dulu. Hirarki kekuatan operator secara berturut-turut adalah ^, * dan /, \, mod, + dan -. Operator * dan / adalah setara. Demikian juga operator + dan -. Perhatikan contoh berikut ini. Contoh 7.3. Contoh penggunaan hirarki operator aritmatika. 5 * 2 + 3 = 13 4 ^ 2 - 5 = 11 Pada contoh pertama, tanda * (kali) memiliki kekuatan yang lebih tinggi dari tanda + (tambah) sehingga operasi perkalian dilakukan terlebih dahulu daripada penjumlahan. Hasil yang diperoleh adalah 10 ditambah 3 bukan 5 dikali 5. Sedangkan pada contoh kedua, tanda ^ (pangkat) mempunyai urutan kekuatan lebih tinggi dari – (kurang) sehingga hasil akhirnya adalah 11 (yaitu dari 16 dikurangi 5). Untuk merubah urutan proses aritmatika dapat diatur dengan menggunakan tanda kurung. Perhatikan contoh berikut : Contoh 7.4. Contoh penggunaan kurung untuk mengatur hirarki operator. 5 * (2 + 3) = 25 4 ^ (2 – 5) = 0.015625 Pada contoh ini kita menggunakan angka dan operator yang sama seperti contoh sebelumnya, namun dengan menggunakan tanda kurung untuk merubah urutan proses. Pada contoh pertama proses yang pertama dilakukan adalah penjumlahan 2 dan 3, kemudian baru dikalikan 5. Hasil akhirnya adalah Rekayasa Perangkat Lunak 149 25 (bandingkan dengan contoh sebelumnya, yaitu 13). Sedangkan pada contoh kedua proses pertama adalah 2 dikurangi 5 kemudian baru hasilnya digunakan sebagai angka pangkat untuk 4 (menjadi 4^-3). Hasil yang diperoleh adalah 0.015625, berbeda jauh dengan contoh sebelumnya yaitu 11. Dari kedua contoh ini dapat dilihat bahwa tanda kurung memiliki kekuatan lebih tinggi dari operator lainnya. Apabila ada lebih dari satu tanda kurung berjajar maka tanda kurung paling dalam yang akan diproses terlebih dahulu. Perhatikan contoh berikut : 5 * ((2 + 2) / 8) = 2.5 • Operator perbandingan Operator perbandingan digunakan untuk membandingkan nilai data. Simbol-simbol yang digunakan : operasi yang Tabel 7.2. Operator perbandingan. • Operator logika Operator logika digunakan untuk operasi yang membandingkan suatu perbandingan. Simbol-simbol yang digunakan : Tabel 7.3. Operator logika. 7.1.4. Struktur Kontrol Program Struktur kontrol program atau kadang disebut sebagai struktur kendali merupakan penerapan dari algoritma struktur percabangan dan struktur pengulangan. Buka kembali Bab 5 untuk memperjelas kembali tentang struktur algoritma. 150 Rekayasa Perangkat Lunak • Struktur percabangan. Struktur percabangan dalam Visual Basic dapat dilakukan dengan menggunakan If ... Then dan Select ... Case. If ... then digunakan jika percabangan tidak terlalu banyak. Sedangkan Select ... Case digunakan jika ada banyak percabangan. Perhatikan contoh penulisan If ... Then ini. Contoh 7.5. Contoh penulisan If .. Then. ' Percabangan/pemilihan satu baris tanpa Else If x > 0 Then y = x ' Percabangan/pemilihan satu baris dengan Else If x > 0 Then y = x Else y = 0 ' Percabangan/pemilihan satu baris dengan Else dan titik dua If x > 0 Then y = x: x = 0 Else y = 0 ' Percabangan ditulis dengan cara lebih dari satu baris If x > 0 Then y = x x = 0 Else y = 0 End If ' Penggunaan blok if If x > 0 Then y = x ElseIf x < 0 Then y = x * x Else x = -1 End If Contoh 7.6. Contoh penulisan Select ... Case. Dim position As Integer 'Pilihan position = CInt(txtPosition.Text) Select Case position Case 1 txtOutcome.Text = "Menang" Case 2 txtOutcome.Text = "Kalah" Case 3 txtOutcome.Text = "Seri" Case Else txtOutcome.Text = "Tidak bertanding." End Select Rekayasa Perangkat Lunak 151 Coba perhatikan contoh aplikasi dengan menggunakan If ... Then dan Select ... Case berikut ini. Contoh 7.7. Program aplikasi dengan if ... then. Aktifkan VB 6 kemudian buatlah form sebagai berikut : Atur property untuk masing-masing obyek sebagai berikut : Buka Jendela Code dan pada bagian Code Editor ketikkan kode programnya sebagai berikut : Private Sub Command1_Click() If Text1.Text = "nusantara" Then Image1.Visible = True End Sub Klik menu Project > Project1 Properties lalu klik tab General. Gantilah Startup Object-nya menjadi Form5. Coba jalankan Project1 : 152 o Ketikkan sembarang teks pada TextBox lalu klik tombol OK atau tekan Enter, tidak terjadi apa-apa. o Ketikkan “nusantara” pada TextBox lalu klik tombol OK atau tekan Enter, gambar computer akan muncul. Rekayasa Perangkat Lunak Penjelasan kode program : Modifikasi kode programnya menjadi sebagai berikut : Private Sub Command1_Click() If Text1.Text = "nusantara" Then Image1.Visible = True Text1.Enabled = False Command1.Enabled = False Else MsgBox "Passwordnya Salah !" Text1.Text = "" Text1.SetFocus End If End Sub Coba jalankan kembali Project1 : • Ketikkan sembarang teks pada TextBox lalu klik tombol OK atau tekan Enter, muncul kotak pesan “Passwordnya Salah !”. Klik tombol OK pada kotak pesan tersebut. • Ketikkan “nusantara” pada TextBox lalu klik tombol OK atau tekan Enter, gambar computer akan muncul. TextBox dan tombol OK menjadi disable (tidak bisa digunakan). Penjelasan kode program : Rekayasa Perangkat Lunak 153 Catatan tambahan : o Teks “nusantara” harus diketik huruf kecil semua. Ingat : data string bersifat case sensitive ! o Agar password-nya tidak bersifat pernyataan kondisinya menjadi : case sensitive, modifikasi If LCase(Text1.Text) = "nusantara" Then Fungsi LCase adalah untuk mengkonversi semua string yang diinput ke Text1.Text menjadi huruf kecil, walaupun user menginputnya dengan huruf kapital. Contoh 7.8. Program aplikasi dengan Select ... Case. Aktifkan VB 6 melalui tombol Start, kemudian buat form sebagai berikut : Atur property untuk masing-masing obyek sebagai berikut : 154 Rekayasa Perangkat Lunak Buka Jendela Code dan pada bagian Code Editor ketikkan kode programnya sebagai berikut : Private Sub Form_Load() List1.AddItem "Disket" List1.AddItem "Buku" List1.AddItem "Kertas" List1.AddItem "Pulpen" End Sub Private Sub Command1_Click() Dim harga As Currency, total As Currency Dim jumlah As Integer Dim diskon As Single Dim satuan As String If List1.Text = "" Then MsgBox "Anda belum memilih barang !!" List1.ListIndex = 0 Exit Sub End If If Text1.Text = "" Then MsgBox "Anda belum mengisi jumlah barang !!" Text1.SetFocus Exit Sub End If Select Case List1.Text Case "Disket" harga = 35000 satuan = "Box" Case "Buku" harga = 20000 satuan = "Lusin" Case "Kertas" harga = 25000 satuan = "Rim" Case "Pulpen" harga = 10000 satuan = "Pak" End Select lblBarang.Caption = "Barang : " & List1.Text lblHarga.Caption = "Harga : " & Format(harga, "Currency") & "/" & satuan lblJumlah.Caption = "Jumlah : " & Text1.Text & " " & satuan jumlah = Text1.Text Select Case jumlah Case Is < 10 diskon = 0 Case 10 To 20 diskon = 0.15 Case Else Rekayasa Perangkat Lunak 155 diskon = 0.2 End Select total = jumlah * (harga * (1 - diskon)) lblDiskon.Caption = "Diskon : " & Format(diskon, "0 %") lblTotal.Caption = "Total Bayar : " & Format(total, "Currency") End Sub Klik menu Project > Project1 Properties lalu klik tab General. Gantilah Startup Object-nya menjadi Form6. Coba jalankan Project1 : o List1 akan terisi nama-nama barang. o Klik tombol OK, akan muncul kotak pesan "Anda belum memilih barang !!". o Klik OK, nama barang pertama akan terpilih secara otomatis. Anda boleh memilih nama barang yang lainnya. o Klik tombol OK, akan muncul kotak pesan "Anda belum mengisi jumlah barang !!". o Klik OK, text1 akan menjadi focus. Isi jumlah barangnya, misalnya : 10. o Klik tombol OKm akan tampil : nama barang, harga barang (persatuannya), jumlah barang (dengan satuannya), diskon dan total bayar. o Coba ganti pilihan nama barang (pada List1) dan jumlah barang (pada Text1) lalu klik lagi tombol OK. 156 Rekayasa Perangkat Lunak Penjelasan kode program : Catatan : o Bila jumlah barang diisi dengan selain angka akan muncul pesan error. o Untuk mengecek isi Text1 angka atau bukan, tambahkan kode berikut : If Not IsNumeric(Text1.Text) Then MsgBox "Isi jumlah barang harus angka !!" Text1.SetFocus Exit Sub End If Rekayasa Perangkat Lunak 157 • Struktur pengulangan. Struktur pengulangan yang mungkin paling banyak digunakan dalam Visual Basic adalah For. Dalam Visual Basic, struktur for ini dikenal sebagai For ... Next. Cara penulisan umum For ... Next adalah sebagai berikut: For counter = nilaiAwal To nilaiAkhir [Step increment] ' pernyataan yang akan diulang... Next Pernyataan Step dan increment sudah disinggung di Bab 5 sehingga tidak akan dibahas lagi di sini. Perhatikan contoh penggunaan For ... Next dalam aplikasi berikut ini. Coba perhatikan contoh pengulangan dengan For ... Next berikut ini. Contoh 7.9. Pengulangan dengan For ... Next. Dim d As Single, count As Long For d = 0 To 10 Step 2 count = count + 1 Next Print count Pada Contoh 7.9, d adalah counter dan kita deklarasikan sebagai single. Kita juga menggunakan increment dengan nilai 2. Nilai increment dapat berupa bilangan bulat atau pecahan. Namun nilai pecahan terkadang memberikan hasil yang tidak kita inginkan. Bagaimanakah output dari program di atas? Pada akhir program maka nilai count akan sama dengan 5. Struktur pengulangan yang lebih fleksibel dari For ... Next adalah Do ... Loop. Do ... Loop dapat berbentuk berbeda-beda. Perhatikan contoh berikut. Contoh 7.10. Pengulangan dengan For ... Next. Do While x > 0 y = y + 1 x = x \ 2 Loop Do y = y + 1 x = x \ 2 Loop Until x <= 0 Pada bagian pertama dari Contoh 7.10 kita menggunakan Do While ... Loop. Cara ini sama persis dengan struktur pengulangan dengan While yang telah kalian pelajari pada Bab 5. Pernyataan di bawah Do While, akan dikerjakan jika kondisi pada Do While bernilai benar. Jika tidak maka tidak akan dieksekusi. 158 Rekayasa Perangkat Lunak Bagian kedua dari Contoh 7.10, kita menggunakan Do ... Loop Until untuk melakukan pengulangan. Pada bentuk seperti ini, pengulangan dilakukan sampai kondisi pada Loop Until bernilai benar. Jadi selama kondisi di depan Loop until masih bernilai salah maka pengulangan akan terus dilakukan. Atau Do ... Loop ini merupakan kebalikan dari Do While. Melihat kedua bagian tersebut, apabila kita inisialisasi x = -4 dan Y = 5, bagaimanakah hasilnya? Pada pengulangan dengan Do While, tidak akan memberikan hasil karena nilai X kurang dari 0 sehingga pengulangan tidak dilakukan. Sedangkan pada Do ... Loop Until, pernyataan di bawah Do masih dikerjakan, karena kondisi baru diperiksa di akhir pengulangan. Sehingga nilai X akan bernilai -2 dan Y bernilai 6. Berikut ini adalah contoh progam aplikasi dengan menggunakan struktur pengulangan. Contoh 7.11. Program aplikasi dengan struktur pengulangan. Buka VB dan buatlah form sebagai berikut : Atur property seperti tabel berikut : Buka Jendela Code dan pada bagian Code Editor ketikkan kode programnya sebagai berikut : Dim i As Integer Private Sub Command1_Click() List1.Clear Rekayasa Perangkat Lunak 159 For i = 1 To 100 List1.AddItem "Angka " & i Next i End Sub Private Sub Command2_Click() List1.Clear For i = 100 To 1 Step -2 List1.AddItem "Angka " & i Next i End Sub Private Sub Command3_Click() List1.Clear i = Asc("A") Do Until i > Asc("Z") List1.AddItem "Huruf " & Chr(i) i = i + 1 Loop End Sub Private Sub Command4_Click() List1.Clear i = Asc("Z") Do While i >= Asc("A") List1.AddItem "Huruf " & Chr(i) i = i - 1 Loop End Sub Coba jalankan program. Tekan keempat tombol yang ada pada form bergantian. Cobalah cermati output apa yang keluar dari eksekusi program di atas. 7.1.5. Prosedur dan Fungsi Ada beberapa jenis procedure yang digunakan dalam Visual Basic : • Sub procedure yang tidak menggembalikan nilai • Function procedure yang mengembalikan nilai • Property procedure yang dapat mengembalikan nilai dan diisi nilai yang mengacu pada suatu objek. 160 Rekayasa Perangkat Lunak • Sub procedure Syntax penulisan Sub procedure: [Private|Public][Static]Sub namaprosedur (argumenargumen) pernyataan-pernyataan End Sub Setiap kali procedure dipanggil, maka pernyataan-pernyataan yang berada di antara Sub dan End Sub akan dijalankan. Argumen pada procedure adalah nilai yang akan dilewatkan saat pemanggilan procedure. Di Visual Basic Sub Procedure dapat dibagi atas dua yaitu : o General Procedure, procedure yang diaktifkan oleh aplikasi. o Event Procedure, Procedure yang diaktifkan oleh system sebagai respon terhadap event. Contoh 7.12. Contoh sub procedure. Pada contoh ini kita akan membuat sub procedure dengan nama CenterForm yang dapat digunakan untuk menampilkan form ketengah Layar, dimana x adalah parameter yang merupakan form yang akan dibuat ketengah layar. Sub CenterForm(x As Form) x.Top = (Screen.Height - x.Height) \ 2 x.Left = (Screen.Width - x.Width) \ 2 End Sub ‘memanggil sub prosedur CenterForm Private Sub Form_Load() Call CenterForm(Me) End Sub Pada contoh 7.12, sub procedure CenterForm membutuhkan argumen form. Sehingga ketika dipanggil argumen juga harus dicantumkan. Perhatikan pada baris Call CenterForm(Me). Me di sini adalah argumen dari sub procedure. Pada Visual Basic, Me merujuk pada form dimana kode program ini dibuat. • Function procedure Ada dua jenis function dalam Visual Basic, yaitu Built-in Function dan Function Procedure. Pada Visual Basic telah disediakan banyak Built-in Function yang dapat digunakan untuk berbagai tujuan seperti fungsi-fungsi untuk perhitungan matematika, manipulasi string, manipulasi tipe data dan lain-lain. Pada bab ini tidak akan dibahas detil fungsi-fungsi built-in tersebut. Namun pada lampiran, dapat dilihat beberapa fungsi built-in yang sering digunakan. Meskipun sudah tersedia sangat banyak, tetapi fungsi-fungsi yang tersedia tersebut bersifat umum dan kandang-kadang tidak memenuhi Rekayasa Perangkat Lunak 161 kebutuhan programer, untuk keperluan tersebut anda dapat menciptakan fungsi-fungsi sendiri yang dikenal dengan Function procedure. Atau kita bisa mengatakan sebagai fungsi buatan sendiri. Sintaks penulisan function procedure : [Private|Public][Static]Function (argumen-argumen) [As type] statements End Function namaprocedure Ada tiga perbedaan antara function dan procedure : o Umumnya anda dapat memanggil suatu function dengan mengikutkan nama function sisi kanan dari statement atau ekspresi. (returnvalue = function()). o Function memiliki type data seperti suatu variabel. Ini menentukan type yang dari nilai yang dikembalikan. o Nilai kembali dimasukkan ke namafunction itu sendirinya, dan suatu function dapat menjadi bagian dari suatu ekspresi yang panjang. Perhatikan contoh fungsi berikut ini. Contoh 7.13. Contoh Fungsi. Fungsi ini adalah fungsi yang bekerja untuk menampilkan nama bulan dalam bahasa Indonesia dari data tanggal yang dimasukkan. Argumen yang dibutuhkan dalam fungsi ini adalah x dan bertipe data date. Function Bulan(x As Date) Dim sRet As String Select Case Case Case Case Case Case Case Case Case Case Case Case Case Case Month(x) 1: sRet = "Januari" 2: sRet = "Februari" 3: sRet = "Maret" 4: sRet = "April" 5: sRet = "Mei" 6: sRet = "Juni" 7: sRet = "Juli" 8: sRet = "Agustus" 9: sRet = "September" 10: sRet = "Oktober" 11: sRet = "Nopember" 12: sRet = "Desember" Else sRet = "tidak sah" End Select Bulan = sRet End Function 162 Rekayasa Perangkat Lunak 7.2. Akses dan Manipulasi Basis Data dengan Visual Basic Salah satu keunggulan Visual Basic dibandingkan dengan Bahasa pemrograman yang lain, adalah kemampuan dalam akse dan manipulasi data. Hal ini karena Visual Basic dikembangkan oleh Microsoft yang juga membuat sistem operasi Windows. Sehingga fungsi-fungsi basis data mendapat dukungan yang sangat lengkap. Visual Basic menyediakan beragam cara untuk mengakses memanipulasi data. Perhatikan diagram pada gambar berikut ini. dan Gambar 7.7. Berbagai cara akse basis data dari Visual Basic. • ODBC Merupakan ODBC singkatan dari Open Data Base Connectivity. sekumpulan fungsi yang membolehkan kita untuk koneksi pada basis data lokal atau yang berada di jaringan. Biasanya ODBC digunakan untuk mengakses berbagai tipe basis data antara lain, MS FoxPro, MS Access, MS SQL Serve, Oracle atau bahka data yang tersimpan dalam bentuk file data. • DAO DAO atau Data Access Object adalah antarmuka dari Microsoft Jet, perangkat utama penggerak MS Access. Kita dapat membuat basis data dengan MS Access kemudian kita manipulasi dengan Visual Basic melalui DAO Rekayasa Perangkat Lunak 163 dengan mudah. Karena DAO langsung berhubungan dengan MS Access, maka kita dapat menggunakan fungsi-fungsi DBMS dari Visual Basic. • OLE DB OLE DB adlah teknologi untuk mengakses basis data level dasar yang sebenarnya dimaksudkan untuk menggantikan fungsi ODBC. Namun dalam perkembangannya ODBC dan OLE DB memiliki perbedaan, yaitu OLE DB berbasis pada teknologi COM dan dapat digunakan untuk mengakses basis data yang bukan bersifat relasional. • ADO ADO (ActiveX Data Object) adalah antarmuka level atas dari OLE DB. ADO dikembangkan di atas OLE DB untuk melengkapi fungsi-fungsi yang tidak dimiliki oleh OLE DB sehingga memudahkan programmer dalam membuat aplikasi. 7.2.1. Membuat dan Manipulasi Basis Data dengan ADO Secara prinsip, apapun metode akses yang digunakan, cara bekerja dengan basis data dari Visual Basic adalah sama. Dibutuhkan beberapa tahapan untuk dapat bekerja dengan basis data. Pada bagian ini kita akan menggunakan ADO sebagai teknologi yang lebih fleksibel dari teknologi yang lain. Tapi ini dapat dikembangkan dengan teknologi yang lain. • Koneksi dengan basis data. Koneksi dengan basis data berarti kita menghubungi basis data supaya terbuka dan bisa kita akses data yang ada didalamnya. Berikut contoh pernyataan untuk koneksi ke basis data biblio.mdb Dim cn As New ADODB.Connection cn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.3.51;" _ & "Data Source=C:\Microsoft Visual Studio\Vb98\Biblio.mdb" • Mengakses record data pada basis data.. Kumpulan dari record-record data dalam basis data, pada ADO disebut sebagai recordset. Untuk bekerja dengan recordset ini kita membutuhkan tabel atau view/query yang ada dalam basis data. Perhatikan contoh berikut ini. Const DBPATH = "C:\Program Files\Microsoft Visual Studio\Vb98\NWind.mdb" Dim cn As New ADODB.Connection, rs As New ADODB.Recordset cn.Open "Provider=Microsoft.Jet.OLEDB.3.51;Data Source=" & DBPATH 164 Rekayasa Perangkat Lunak rs.Source = "Employees" rs.Open , cn Pada kode di atas kita menggunakan basis data Nwind.mdb sebagai Data source. Kemudian sebagai sumber recordset, kita memanggil tabel “Employees”. Variabel rs adalah recordset. Setelah kita tentukan sumber tabelnya, kita dapat membuka tabel tersebut dengan pernyataan open. Setelah terbuka tabel sumbernya, kita dapat mengakses data yang ada di dalamnya. Berikut ini contoh kode untuk mengakses data pada suatu tabel. Dim i As Integer For i = 0 To rs.Fields.Count Print rs.Fields(i).Name & " = " & rs.Fields(i).Value Next Perintah di atas akan mencetak seluruh baris dan kolom Name yang ada pada tabel Employees yang telah terbuka sebelumnya. Cara yang paling cepat adalah dengan menggunakan perintah For Each seperti kode berikut. Dim fld As ADODB.Field For Each fld In rs.Fields Print fld.Name & " = " & fld Next • Manipulasi data dalam recordset Untuk mengupdate data pada suatu recordset dapat dilakukan dengan cara sebagai berikut: rs.Update Array("FirstName", "LastName", "BirthDate", "HireDate"), _ Array("John", "Smith", #1/1/1961#, #12/3/1994#) Sedangkan untuk menambah recordset perintah yang digunakan adalah sebagai berikut: rs.AddNew rs("FirstName") = "Robert" rs("LastName") = "Doe rs("BirthDate") = #2/5/1955# rs.Update Menghapus record tertentu dapat dilakukan dengan perintah seperti berikut. rs.Delete rs.MoveNext If rs.EOF Then rs.MoveLast Rekayasa Perangkat Lunak 165 7.3. Teknologi COM 7.3.1. Pengertian dan Konsep COM COM atau Component Object Model adalah infrastruktur yang disediakan oleh Visual Basic untuk mengakses obyek-obyek atau kontrol-kontrol lain sepanjang punya antar muka yang dapat diakses oleh Visual Basic. Untuk dapat menggunakan COM pada Visual Basic, kita dapat membuka Reference Dialog dengan cara: dari menu Project pilih add Reference. Jendela seperti pada Gambar 7.8 akan terbuka. Gambar 7.8. Jendela Reference. Pada Gambar 7.8 kita memilih COM atau obyek yang ingin kita gunakan. Pada contoh ini kita memilih “Microsoft Word 8.0 Object Library”. Setelah kita klik OK maka kita dapat menggunakan obyek yang kita pilih ini dalam kode program kita. Berikut contoh penggunaan obyek tersebut. Contoh 7.14. Contoh penggunaan COM. Private Dim Dim Dim 166 Sub cmdCheck_Click() text As String suggestion As Word.SpellingSuggestion colSuggestions As Word.SpellingSuggestions Rekayasa Perangkat Lunak ' menambahkan dokumen bila belum ada dokumen yang terbuka. If MSWord.Documents.Count = 0 Then MSWord.Documents.Add text = Trim$(txtWord.text) lstSuggestions.Clear If MSWord.CheckSpelling(text) Then lstSuggestions.AddItem "(correct)" Else Set colSuggestions = MSWord.GetSpellingSuggestions(text) If colSuggestions.Count = 0 Then lstSuggestions.AddItem "(no suggestions)" Else For Each suggestion In colSuggestions lstSuggestions.AddItem suggestion.Name Next End If End If End Sub Pada kode di atas kita menggunaka salah satu metode dari obyek yang kita buka sebelumnya (“Microsoft Word 8.0 Object Library”). Metode yang ingin kita gunakan adalah SpellingSuggestion (lihat kode pada bagian pendeklarasian variabel). Dengan cara yang sama kita dapat menggunakan metode atau fungsi-fungsi yang kita inginkan dari obyek COM yang telah kita muat. Pada jendela Reference di Gambar 7.8, tersedia banyak sekali COM yang dapat kita gunakan. Cobalah untuk membuka satu persatu dan lihat apa fungsinya. 7.4. Ringkasan Pada bab ini kalian telah mempelajari pemrograman dengan Visual Basic. Dimulai dengan penerapan variabel, konstanta, tipe data dan operator. Kemudian dilanjutkan dengan strukturkendali pemrograman baik percabangan maupun pengulangan. Penggunaan procedure dan function juga disampaikan untuk melengkapi dasar pemrograman dengan Visual Basic. Pada bagian selanjutnya kalian juga telah mempelajari teknik akses dan manipulasi data dengan menggunakan ADO. Bagian akhir ditutup dengan bagaimana membuka dan menggunakan teknologi COM yang disediakan oleh Visual Basic. Rekayasa Perangkat Lunak 167 7.5. 1. Soal-Soal Latihan Berapakah hasil dari ekspresi Visual Basic berikut ini: a. b. c. d. e. f. 2. 3*4 7^2 1/(2^3) 3 + (4*5) (5 - 3)*4 3*((-2)^5) Berapakah hasil dari operasi menggunakan mod berikut ini: a. b. c. d. 6 Mod 2 14 Mod 4 7 Mod 3 5 Mod 5 3. Periksalah penamaan variabel dalam Visual Basic ini. Tentukan mana yang diperbolehkan dan yang tidak. a. b. c. d. e. f. sales.2006 room&Board fOrM_1040 1040B expenses? INCOME 2006 4. Jika a = 2, b = 3, dan c = 4, berapakah hasil dari ekspresi berikut ini. a. b. c. d. e. f. (a*b) + c a*(b + c) (1 + b)*c a^c b^(c - a) (c - a)^b 5. Buatlah program untuk menghitung ekspresi berikut ini. a. b. c. d. e. f. 7•8 + 5 (1 + 2•9)3 5.5% of 20 15 - 3(2 + 34) 17(3 + 162) 4 1/2 - 3 5/8 6. Bukalah Gambar 5.6 dan 5.7 pada Bab 5. Buatlah program dalam Visual Basic. Gunakan kontrol TextBox dan CommandButton pada soal ini. 7. Bukalah Gambar 5.9 dan 5.10 pada Bab 5. Buatlah program dalam Visual Basic. 8. Bukalah Gambar 5.15 dan 5.17 pada Bab 5. Buatlah program dalam Visual Basic. 168 Rekayasa Perangkat Lunak BAB 8 PEMROGRAMAN BERORIENTASI OBYEK DENGAN JAVA Gambar cangkir dengan uap mengepul di atasnya serta tulisan Java seperti Gambar 8.1 ini mungkin pernah kalian lihat. Ya, ini adalah logo dari bahasa pemrograman Java yang popularitasnya meningkat beberapa tahun belakangan ini. Banyak game dan aplikasi yang digunakan pada perangkat mobile seperti telepon selular dan PDA dibuat dengan bahasa ini. Bahasa ini dikenal karena portabilitas dan dukungan pada konsep pemrograman berorientasi obyek. Bab ini meliputi dua standar kompetensi, yaitu membuat program dalam bahasa pemrograman berorientasi obyek dan membuat program aplikasi menggunakan Java. Hal ini karena kedekatan konsep antara Java dan pemrograman berorientasi obyek. Standar kompetensi membuat program dalam bahasa Gambar 8.1. Logo Java. pemrograman berorientasi obyek terdiri dari empat kompetensi dasar yaitu tipe data dan kontrol program, pembuatan kelas, penggunaan inheritance, polymorphism, dan overloading, dan penggunaan interface dan paket. Sedangkan standar kompetensi membuat program aplikasi menggunakan Java terdiri dari lima kompetensi dasar, yaitu menjelaskan file I/O, tipe data dan variabel, menerapkan operator, menjelaskan exception handling, menerapkan multithreading dan menjelaskan network programming. Dalam penyajian pada buku ini, satu sub bab tidak langsung merujuk pada satu kompetensi dasar. Ringkasan diletakkan pada setiap akhir bab kemudian dilanjutkan dengan soal-soal latihan. Sebelum mempelajari kompetensi ini ingatlah kembali sistem operasi, prinsip pemecahan masalah, algoritma pemrograman dasar dan lanjutan, pemrograman dengan VB dan VB.Net dan materi-materi pendukung dari mata pelajaran lain. Rekayasa Perangkat Lunak 169 TUJUAN Setelah mempelajari bab ini diharapkan pembaca akan mampu : o Memahami konsep pemrograman berorientasi obyek o Menjelaskan File I/O, tipe data dan variabel pada Java o Menggunakan operator o Menerapkan kontrol program o Menjelaskan Exception Handling o Menerapkan Multi-Threading o Menjelaskan Network Programming o Membuat program berorientasi obyek dengan class o Menggunakan prinsip inheritance, polymorphism dan overloading o Membuat program berorientasi obyek dengan interface dan paket 8.1. KONSEP PEMROGRAMAN BERORIENTASI OBYEK Pemrograman Berorientasi Obyek (Object Oriented Programming – OOP) adalah programming paradigm yang menggunakan obyek dan interaksinya untuk merancang aplikasi dan program komputer. OOP tidak banyak digunakan sebelum awal tahun 1990an. Tapi sekarang menjadi sesuatu yang sudah lumrah digunakan. Bahasa-bahasa pemrograman seperti keluarga dotNet dari Microsoft (Visual Basic.Net, Visual C#, dan Visual J), Borland Delphi, Java, Phyton, PHP versi 5 ke atas, C++ dan banyak lainnya merupakan bahasa pemrograman yang mendukung konsep OOP. Apakah obyek itu? Semua benda yang ada didunia ini dapat kita sebut sebagai obyek. Guru mata pelajaran RPL kalian adalah suatu obyek. Buku yang kalian pegang ini juga suatu obyek. Bahkan mata pelajaran RPL adalah juga sebuah obyek. Setiap obyek akan mempunyai karakteristik dan tingkah laku tertentu. Karakteristik disebut attribute dan tingkah laku disebut sebagai behavior atau method. Dalam difinisi pemrograman berorientasi obyek dikenal adanya kelas dan obyek. Class atau kelas mendefinisikan karakteristik abstrak dari sesuatu termasuk atribut atau sifat-sifat dari sesuatu dan apa yang dapat dikerjakan oleh sesuatu (method). Sebagai contoh, mobil adalah sebuah kelas yang memiliki attribut warna, merek, tipe dan lain-lain. Mobil juga punya method antara lain, maju, mundur dan berhenti (lihat Gambar 8.2). Gambar 8.2. Kelas, atribut dan method. 170 Rekayasa Perangkat Lunak Obyek adalah contoh dari kelas yang sudah didefinisikan. Atribut dan method dari kelas secara otomatis akan menurun pada obyek namun dengan kekhususan. Sebagai ilustrasi kita perhatikan Gambar 8.2. Pada gambar tersebut, kita bisa identifikasi kelasnya adalah mobil dengan atribut dan methodnya. Obyeknya adalah sebuah mobil sedan dengan merk Toyota, dan warnanya adalah merah. Sedan itu juga memiliki method maju, mundur dan berhenti. Pada kasus ini mobil sedan disebut sebagai instance atau turunan dari kelas mobil. Ada beberapa konsep penting yang kalian harus pahami dalam pemrograman berorientasi yaitu, abstraksi, enkapsulasi, inheritance dan polymorphism. 8.1.1. Abstraksi Abstraction atau disebut juga composition merupakan prinsip penyederhanaan dari sesuatu yang kompleks dengan cara memodelkan kelas sesuai dengan masalahnya. Untuk lebih memperjelas pengertian coba perhatikan Gambar 8.3. Pada gambar tersebut terlihat sebuah mobil jika dipecah-pecah bagian-bagiannya kita akan dapatkan seperti ban, mesin, rangka mobil, kaca, dan lain-lain dan hal in berlaku sebaliknya. Jika kita gabungkan bagian-bagian tersebut maka kita akan mendapatkan sebuah kelas mobil. Pada pemrograman berorientasi obyek biasanya kalau kita menjumpai beberapa kelas atau obyek yang kalau diidentifikasi memiliki banyak kesamaan atribut dan method maka kita akan menggabungkan kelas-kelas tersebut menjadi satu super class. Gambar 8.3. Contoh abstraction. 8.1.2. Enkapsulasi Prinsip encapsulation adalah prinsip penyembunyian detil dari sebuah kelas terhadap obyek yang berinteraksi terhadapnya. Sebagai contoh ketika kita menjalankan mobil, sebenarnya kita sedang berinteraksi dan kita meminta kepada mobil untuk menjalankan methodnya seperti maju, mundur atau berhenti. Kita berinteraksi hanya dengan beberapa bagian dari mobil (interface) seperti persneling, setir, pijakan gas, pijakan rem dan bagian lain. Tapi detil proses yang terjadi didalam mobil bagaimana bisa maju, mundur atau berhenti kita tidak perlu tahu. Rekayasa Perangkat Lunak 171 8.1.3. Inheritance Inheritance atau pewarisan adalah prinsip pewarisan sifat dari orang tua ke anak atau turunannya yang diterapkan pada kelas. Orang tua memiliki atribut dan method yang lebih umum dibandingkan dengan anak atau turunannya. Pada Gambar 8.4. kita bisa tahu bahwa mobil memiliki atribut dan method yang lebih umum dibandingkan dengan sedan , truk atau bus. Mobil sebagai kelas yang mewarisi disebut sebagai super class, sedangkan sedan, truk dan bus sebagai kelas yang diwarisi disebut sub class. Gambar 8.4. Pewarisan. 8.1.4. Polymorphism Polymorphism mungkin merupakan konsep pemrograman beroerientasi obyek yang paling sulit dimengerti. Arti dari polymorphism adalah kemampuan dari suatu obyek untuk mempunyai lebih dari satu bentuk. Atau dalam pengertian lain adalah kita dapat menerapkan sesuatu hal yang berbeda melalui suatu cara yang sama. Sebagai contoh kalau ada empat ekor hewan berbeda yaitu burung, ular, katak, dan singa kemudian kita minta untuk bergerak, maka burung akan terbang, ular akan melata, katak melompat, singa mungkin akan berlari. Jadi suatu method yang sama mungkin bisa diterapkan secara lain jika obyek yang menerapkan adalah berlainan. 8.2. PENGENALAN PADA JAVA Bahasa pemrograman Java pertama lahir dari The Green Project, yang berjalan selama 18 bulan, dari awal tahun 1991 hingga musim panas 1992. Proyek tersebut menggunakan versi yang dinamakan Oak. Nama Oak ini tidak dipakai untuk versi release Java karena sebuah perangkat lunak sudah terdaftar dengan merek dagang tersebut, sehingga diambil nama penggantinya menjadi "Java". Nama ini diambil dari kopi murni yang digiling langsung dari biji (kopi tubruk). Saat ini Java berada dibawah lisensi Sun Microsystems Menurut definisi dari Sun, Java adalah nama untuk sekumpulan teknologi untuk membuat dan menjalankan perangkat luinak pada komputer standalone ataupun pada lingkungan jaringan. Orang orang yang berkecimpung dalam dunia pemrograman lebih suka menyebut Java sebagai sebuah teknologi 172 Rekayasa Perangkat Lunak dibanding hanya sebuah bahasa pemrograman, karena Java lebih lengkap dibanding sebuah bahasa pemrograman konvensional. 8.2.1. Kebutuhan Perangkat Lunak Untuk membuat program Java paling tidak harus tersedia dua buah software yaitu: • Java 2 SDK Standard Edition (J2SE). Perangkat lunak ini merupakan yang akan kita gunakan untuk mengkompilasi kode program Java yang kita buat. Selain itu pada perangkat lunak ini tersedia kelas-kelas yang dapat kita gunakan untuk membangun aplikasi desktop, grafis, keamanan, konektivitas basis data dan jaringan. Perangkat lunak ini dapat di-download gratis di situs Sun Microsystem. Setelah itu perangkat lunak ini harus diinstal pada system operasi yang kita pakai. • Text Editor. Perangkat lunak ini berfungsi untuk menuliskan kode-kode program. Notepad, Vi, Gedit, merupakan contoh-contoh teks editor yang dapat digunakan. Namun menggunakan teks editor agak menyulitkan karena tidak tersedia fasilitas bantu yang memudahkan dalam menuliskan kode program. Saat ini beberapa IDE tersedia gratis di internet. IDE tersebut telah menyediakan banyak fasilitas seperti syntax coloring, auto completion, dan template untuk memudahkan membuat aplikasi berbasis Java. NetBeans (www.netbeans.org) dan Eclipse (www.eclipse.org) merupakan dua buah IDE yang sangat terkenal dan sangat kuat. Gambar 8.5. menunjukkan tampilan NetBeans IDE. Rekayasa Perangkat Lunak 173 Gambar 8.5. NetBeans IDE. 8.2.2. Kompilasi Kode Program Sebelum kita membuat program dan mengkompilasinya kita harus mengatur ClassPath. ClassPath adalah suatu sistem variabel yang digunakan untuk mengatakan pada program yang ditulis dengan bahasa Java tempat lokasi-lokasi yang akan digunakan. Misalkan kita meletakkan kode program kita di direktori d:\TestCode\Java, maka kita perlu mengatur path agar kita bisa menggunakan compiler java dari direktori ini. Berikut ini langkahlangkah membuat classpath: • Buka command-prompt di Windows kemudian setelah terbuka ketikkan : Set PATH=C:\progra~1\java\jdk1.5.0\bin;%PATH% Set CLASSPATH=.;D:\TestCode\Java Path di atas adalah jika kita menggunakan JDK versi 1.5, jika versi yang lain maka tinggal menyesuaikan. • Periksa apakah setting sudah benar dengan mengetikkan perintah java pada direktori manapun dari command prompt. Setelah classpath terbentuk, coba buka Notepad kemudian ketikkan kode berikut ini. public class Main { //isi blok public static void main(String[] args) { System.out.println("Hallo ini Java lho"); } } Kemudian simpan file kode tersebut dengan nama yang sama dengan class yang ada pada kode tersebut yaitu Main dan diakhiri dengan ekstensi .java. Simpan di lokasi yang telah kita tetapkan di atas (lihat Gambar 8.6). Aturan penulisan nama file di Java sangat ketat, sehingga jika kalian member nama file tidak sama dengan nama kelasnya, maka program akan menolak untuk dieksekusi. Pada kode program di atas, baris pertama menunjukkan nama class yaitu Main. Pada Java semua kode seharusnya ditempatkan didalam deklarasi class. Kita melakukannya dengan menggunakan kata kunci class. Sebagai tambahan, class menggunakan akses khusus public, yang menunjukkan bahwa class kita mempunyai akses bebas ke class yang lain dari package yang lain pula (package merupakan kumpulan class-class). Setelah deklarasi class kemudian diikuti tanda { yang menunjukkan awal blok kode. Tanda ini harus ditutup dengan tanda } sebagai akhir blok. Baris yang dimulai dengan tanda // adalah komentar. Kemudian baris berikutnya adalah deklarasi nama method. Dalam hal ini nama method-nya 174 Rekayasa Perangkat Lunak adalah main (method utama). Kita dapat membuat method-method lainnya diluar main ini. Setelah deklarasi ini diikuti juga dengan blok kode. Pada blok kode berisi pernyataan System.out.println("Hallo ini Java lho");. Perintah System.out.println(), menampilkan teks yang diapit oleh tanda petik ganda (“ ”) pada layar. Gambar 8.6. Nama file dan lokasi penyimpanan. Sekarang buka command prompt dan arahkan ke direktori tempat file java kalian simpan dan ketikkan seperti pada Gambar 8.7. Perhatikan cara penulisan dan hasil yang diperoleh. Gambar 8.7. Cara eksekusi program dalam Java. Sebelum dapat dieksekusi, maka kode program (Main.java) harus dikompilasi dengan menggunakan perintah javac seperti terlihat di Gambar 8.7. Setelah kompilasi berhasil, maka program dapat kita eksekusi dengan Rekayasa Perangkat Lunak 175 menggunakan perintah java. Proses kompilasi akan menghasilkan file dengan nama Main.class (periksa direktori kalian dengan perintah dir, dan cari file dengan akhiran .class). Yang kita panggil pada perintah java adalah file dengan akhiran class ini dan bukan lagi kode sumber yang berakhiran .java. 8.3. TIPE DATA, VARIABEL, DAN PERNYATAAN INPUT/OUTPUT (I/O) 8.3.1. Tipe Data Ada 8 tipe data dasar pada Java yaitu boolean (untuk bentuk logika), char (untuk bentuk tekstual), byte, short, int, long (integral), double and float (floating point). Tabel 8.1 berikut menunjukkan penjelasan tentang tipe data tersebut. Tabel 8.1. Tipe data pada Java. Tipe Data logika (boolean) tekstual (char) Integral (byte, short, int & long) Floating Point (float dan double) Penjelasan diwakili oleh dua pernyataan : true dan false harus memiliki ciri berada dalam tanda single quotes(’ ’) Tipe data bilangan bulat, default tipe data yaitu int. byte = 8 bits dengan range -27 s/d 27-1 short = 16 bits dengan range -215 s/d 215-1 int = 32 bits dengan range -231 s/d 231-1 long = 64 bits dengan range -263 s/d 263-1 Tipe data bilangan asli (boleh ada pecahan). Default tipe datanya adalah double. float = 32 bits dengan range -231 s/d 231-1 double= 64 bits dengan range -263 s/d 263-1 Pada Java, String bukan merupakan tipe data primitif (namun merupakan suatu Class). String mewakili tipe data yang terdiri atas beberapa karakter. String ditulis dengan menggunakan tanda petik ganda (“”). Contoh-contoh berikut menunjukkan bagaimana menggunakan tipe-tipe data di atas. Ketikkan kode pada contoh-contoh berikut kemudian kompilasi dan jalankan. Perhatikan output dari program. Contoh 8.1. Penggunaan tipe data integral. public class ContohPerhitungan { public static void main(String[] args) { byte a = 1; short b = 12; int c = 300, d, e; d = a + b + c; e = a * b * c; System.out.println("Hasil penjumlahan = " + d); System.out.println("Hasil perkalian = " + e); 176 Rekayasa Perangkat Lunak } } Contoh 8.2. Penggunaan tipe data float. public class LuasLingkaran { public static void main(String[] args) { double pi = 3.1416; double r = 2.12; double luas; luas = pi * r * r; System.out.println("Luas Lingkaran = " + luas); } } Contoh 8.3. Penggunaan tipe data char. public class tipeChar { public static void main(String[] args) { char ch = 'A'; System.out.println("ch = " + ch); ch++; System.out.println("ch = " + ch); } } 8.3.2. Variabel dan Konstanta Aturan penamaan (identifier) variabel dan konstanta seperti terdapat pada Bab 5 juga berlaku pada Java. Selain itu penulisan identifier pada Java bersifat case-sensitive. Artinya huruf besar dan huruf kecil dianggap suatu yang berbeda. Tidak seperti pada VB, Java mensyaratkan kita mendeklarasikan variabel dan konstanta lebih dulu. Kalau tidak maka kode program tidak akan dapat dikompilasi. Cara pendeklarasian variabel adalah sebagai berikut: [=nilai awal]; Nilai awal bersifat opsional atau boleh dicantumkan atau tidak. Perhatikan contoh 8.1 di atas. Variabel a, b, dan c telah ditentukan nilai awalnya. Sedangkan variabel d dan e tidak ditentukan nilainya. Perhatikan juga contoh 8.2 dan 8.3 untuk pendeklarasian variabel. 8.3.3. Input / Output Pada contoh-contoh kode program di atas sebenarnya kita telah menggunakan salah satu cara untuk menampilkan output ke layar, yaitu perintah System.out.println, namun kita belum pernah menggunakan pernyataan Rekayasa Perangkat Lunak 177 untuk mendapatkan input. Berikut ini kita akan menggunakan pernyataan input dan output pada Java. pelajari bagaimana Untuk dapat menangkap input dari keyboard, maka kita harus menggunakan kelas BufferedReader yang berada di java.io package. Sehingga di awal program kita harus mencantumkan kelas tersebut pada kode program. Perhatikan contoh berikut. Contoh 8.4. Pernyataan input pada Java. import java.io.BufferedReader; import java.io.InputStreamReader; import java.io.IOException; public class InputKeyboard { public static void main( String[] args ){ BufferedReader dataIn = new BufferedReader(new InputStreamReader( System.in) ); String name = ""; System.out.print("Ketikkan nama anda:"); try{ name = dataIn.readLine(); }catch( IOException e ){ System.out.println("Error!"); } System.out.println("Hai " + name +"!"); } } Tiga baris yang diawali dengan perintah import menunjukkan bahwa kita akan menggunakan kelas BufferedReader, InputStreamReader dan IOException yang berada di java.io package. Penjelasan tentang package akan kita bahas pada bagian lain dari bab ini. Pada statement, BufferedReader dataIn = new BufferedReader(new InputStreamReader( System.in) ); kita mendeklarasikan sebuah variabel bernama dataIn dengan tipe kelas BufferedReader. Kemudian, kita mendeklarasikan variabel String dengan identifier name. Pernyataan ini digunakan untuk menunjukkan tempat menyimpan input dari pengguna. Variabel name diinisialisasi sebagai String kosong "". Baris berikutnya adalah memberikan output string seperti yang telah kita pelajari dengan menggunakan pernyataan System.out.print; 178 Rekayasa Perangkat Lunak Sekarang, blok di bawah ini merupakan try-catch blok (kita akan bahas tentang ini di sub bab exception) try{ name = dataIn.readLine(); }catch( IOException e ){ System.out.println("Error!"); } Pada baris ini menjelaskan bahwa kemungkinan terjadi error pada statement name = dataIn.readLine(); akan ditangkap. Jika ada kesalahan maka tulisan “Error” akan disampaikan. Jika tidak ada kesalahan maka variabel name akan diisi dengan apa yang dimasukkan oleh pengguna melalui keyboard. Dan akan ditampilkan pada pernyataan terakhir. Untuk menampilkan output yang kita inginkan, dapat menggunakan perintah sebagai berikut : System.out.println() System.out.print() System.out.println()akan membuat baris System.out.print() tidak akan membuat baris baru. baru sedangkan 8.4. OPERATOR 8.4.1. Operator Aritmatika Operator aritmatika yang digunakan pada Java hampir sama dengan yang digunakan pada VB. Hanya pada penggunaan operator modulus yang berbeda notasinya. VB menggunakan mod sedangkan Java menggunakan tanda %. Tabel 8.2 menunjukkan operator aritmatika yang ada di Java. Tabel 8.2. Operator aritmatika pada Java Operator + * / % ++ -- Fungsi Penjumlahan Pengurangan Perkalian Pembagian Sisa hasil bagi (modulus) Menambahkan nilai 1 ke variabel (increment) Mengurangi nilai 1 ke variabel Contoh 3+5=8 7–2=5 5 * 2 = 10 6/3=2 5/2=1 C++ = C + 1 C-- = C - 1 Contoh berikut menunjukkan bagaimana menggunakan operator aritmatika. Ketikkan kode pada contoh berikut kemudian kompilasi dan jalankan. Perhatikan output dari program. Rekayasa Perangkat Lunak 179 Contoh 8.4. Penggunaan operator aritmatika. public class DemoAritmatika { public static void main(String[] args) { int i = 21; int j = 38; double x = 9.123; double y = 12.78; //Cetak nilai variabel System.out.println("Nilai Variabel..."); System.out.println(" i = " + i); System.out.println(" j = " + j); System.out.println(" x = " + x); System.out.println(" y = " + y); //penjumlahan System.out.println("Penjumlahan..."); System.out.println(" i + j = " + (i + j)); System.out.println(" x + y = " + (x + y)); //pengurangan System.out.println("Pengurangan..."); System.out.println(" i - j = " + (i - j)); System.out.println(" x - y = " + (x - y)); //perkalian System.out.println("Perkalian..."); System.out.println(" i * j = " + (i * j)); System.out.println(" x * y = " + (x * y)); //pembagian System.out.println("Pembagian..."); System.out.println(" i / j = " + (i / j)); System.out.println(" x / y = " + (x / y)); //modulus System.out.println("Sisa Hasil Bagi..."); System.out.println(" i % j = " + (i % j)); System.out.println(" x % y = " + (x % y)); //increment System.out.println("Increment..."); System.out.println(" i++ = " + (i++)); System.out.println(" ++i = " + (++i)); System.out.println(" j++ + i = " + (j++ + i)); System.out.println(" ++j + i = " + (++j + i)); } } 8.4.2. Operator Relasional Operator relasional atau perbandingan pada Java juga mirip dengan VB. Hanya berbeda pada perbandingan symbol sama dan tidak sama. Pada VB untuk membandingkan dua buah operand apakah sama atau tidak menggunakan 180 Rekayasa Perangkat Lunak operator = untuk sama dengan dan <> untuk tidak sama dengan. Sedangkan pada java digunakan == untuk sama dengan dan != untuk tidak sama dengan. Ketikkan kode pada contoh berikut kemudian kompilasi dan jalankan. Perhatikan output dari program. Contoh 8.5. Penggunaan operator relasional. public class DemoRelasional { public static void main(String[] args) { int i = 20; int j = 16; int k = 16; //Cetak nilai variabel System.out.println("Nilai variabel..."); System.out.println(" i = " + i); System.out.println(" j = " + j); System.out.println(" k = " + k); //lebih besar dari System.out.println("Lebih besar dari..."); System.out.println(" i > j = " + (i > j)); System.out.println(" j > i = " + (j > i)); System.out.println(" k > j = " + (k > j)); //lebih besar atau sama dengan System.out.println("Lebih besar atau sama dengan..."); System.out.println(" i >= j = " + (i >= j)); System.out.println(" j >= i = " + (j >= i)); System.out.println(" k >= j = " + (k >= j)); //lebih kecil dari System.out.println("Lebih kecil dari..."); System.out.println(" i < j = " + (i < j)); System.out.println(" j < i = " + (j < i)); System.out.println(" k < j = " + (k < j)); //lebih kecil atau sama dengan System.out.println("Lebih kecil atau sama dengan..."); System.out.println(" i <= j = " + (i <= j)); System.out.println(" j <= i = " + (j <= i)); System.out.println(" k <= j = " + (k <= j)); //sama dengan System.out.println("Sama dengan..."); System.out.println(" i == j = " + (i == j)); System.out.println(" k == j = " + (k == j)); //tidak sama dengan System.out.println("Tidak sama dengan..."); System.out.println(" i != j = " + (i != j)); System.out.println(" k != j = " + (k != j)); } } Rekayasa Perangkat Lunak 181 8.4.3. Operator Logika .Ada 3 operator logika yang disediakan Java yaitu: && (AND), || (logika OR), | dan ! (logika NOT). Penggunaan operator ini sama persis dengan yang ada pada VB. Hanya notasinya saja yang berbeda. 8.5. STRUKTUR KONTROL PROGRAM Seperti halnya pada VB, pada Java juga menyediakan struktur kontrol program untuk pemilihan maupun pengulangan. Perintah yang digunakan dalam struktur kontrol ini juga hampir mirip. 8.5.1. Struktur Pemilihan Struktur pemilihan dapat menggunakan if, if … else, dan if …else … if. Hal ini tidak berbeda jauh dengan apa yang telah kalian pelajari pada Bab 5 dan Bab 7. Perhatikan potongan kode-kode program berikut. Contoh 8.6. Penggunaan if. int nilai = 68; if( nilai > 60 ) System.out.println("Selamat anda lulus!"); Contoh 8.6 ini hanya menggunakan if untuk membuat struktur pemilihan. Jika nilai lebih dari 60 maka program akan menampilkan output “Selamat anda lulus!” Contoh 8.7. Penggunaan if … else. int nilai = 68; if( nilai lulus!"); else > 60 ) System.out.println("Selamat anda System.out.println("Anda tidak lulus!"); Pada contoh 8.7, kita menggunakan struktur if … else. Jika nilai lebih dari 60 maka akan menampilkan output “Selamat anda lulus!” tetapi jika tidak (else) maka program akan menampilkan output “Anda tidak lulus!”. Contoh 8.8. Penggunaan if … else … if. int nilai = 68; if( nilai > 90 ){ System.out.println("Nilai anda sangat baik!"); 182 Rekayasa Perangkat Lunak } else if( nilai > 60 ){ System.out.println("Nilai anda baik!"); } else{ System.out.println("Anda tidak lulus"); } Contoh 8.8 merupakan pengembangan dari contoh 8.7. Jika nilai lebih dari 90 maka program akan menampilkan output “Nilai anda sangat baik!”, tetapi jika kurang dari 90 dan lebih dari 60 (else if) maka program akan menampilkan output “Nilai anda baik!” dan jika tidak kedua-duanya (else) maka program akan menampilkan output “Anda tidak lulus” Struktur pemilihan juga memungkinkan kita untuk memilih banyak alternatif. Namun jika menggunakan if akan sangat kompleks. Java menyediakan perintah switch. Perintah ini sama fungsinya dengan Select .. case pada VB. Perhatikan contoh berikut. Contoh 8.9. Penggunaan switch. public class SwitchControl { public static void main(String[] args) { int a=2; int b; switch(a) { case 1: b = a + 1; break; case 2: b = a + 2; break; case 3: b = a + 3; break; case 4: b = a + 4; break; default: b = 0; } System.out.println("Nilai b: " + b); } } Berapakah hasil dari kode program pada contoh 8.9 di atas. Kalau jawaban kalian 4 berarti kalian telah memahami bagaimana cara kerja perintah switch. Switch akan memeriksa apakah ada case yang memiliki nilai sama dengan a yaitu 2. Pemeriksaan dimulai dari case pertama yaitu 1. Pernyataan break harus dituliskan untuk menghentikan pencarian pada case berikutnya. Cobalah hilangkan pernyataan break dan jalankan kode program di atas. Bagaimanakah hasilnya? Rekayasa Perangkat Lunak 183 8.5.2. Struktur Pengulangan Ada tiga bentuk struktur pengulangan pada Java yaitu for, while dan doSecara prinsip bentuk pengulangan ini sama dengan apa yang telah kalian pelajari pada Bab 5 dan 7. Berikut ini contoh-contoh bentuk pengulangan. while. Contoh 8.10. Penggunaan for pada Java. public class ForLoop { public static void main(String[] args) { int j=4; for (int x=0; x < 5; x++) { System.out.println("Nilai x: " + x); System.out.println("Nilai j: " + j); System.out.println(); j--; } } } Sintaks umum for adalah : for (nilai awal; kondisi; increment) kemudian dilanjutkan dengan bagian yang akan diulang. Perhatikan baik-baik bagaimana menggunakan struktur for pada contoh 8.10 di atas. Nilai x=0 adalah nilai awal. Sedangkan x < 5 adalah kondisi yang harus dipenuhi agar pengulangan bisa dilakukan. Nilai x++ merupakan increment. Ingat bahwa penulisan x++ sama artinya dengan x = x + 1. Cobalah jalankan kode program di atas. Menurut kalian bagaimanakah keluaran dari program tersebut? Contoh 8.11. Penggunaan while pada Java. public class WhileLoop { public static void main(String[] args) { int y = 4; while ( y > 0 ){ System.out.print(y); y--; } } } Pada contoh 8.11 ini kita menggunakan while untuk membuat pengulangan. Pada while kita perlu menginisialisasi variabel sebelum masuk ke bagian while. Variabel y kita inisialisasi dengan nilai 4. Kondisi yang harus dipenuhi pada while adalah y>0. Pada contoh ini counternya bersifat menurun (perhatikan bagian y--). Sehingga yang akan tercetak dilayar adalah 4321. Bagaimanakah jika baris counter (y--) kita hilangkan? Berapa kalikah pengulangan akan terjadi? Contoh 8.12. Penggunaan do-while pada Java. public class ContohDoWhile { public static void main(String[] args) { int z=3; 184 Rekayasa Perangkat Lunak do { System.out.println("Java"); z++; } while (z < 6); } } Contoh 8.12 menunjukkan bagaimana kita dapat menggunakan do-while untuk mengulang pencetakan kata “Java”. Perhatikan dengan baik sintaks penulisan do-while pada contoh ini. Do-while juga membutuhkan inisialisasi dan counter agar pengulangan dapat dilakukan. Cobalah jalankan program di atas. Berapa kalikah tulisan “Java” akan tampil? Sekarang gantilah kondisi pada while dengan z < 1. Apakah kode program masih mencetak tulisan “Java”? Mengapa? Bacalah kembali Bab 7 pada bagian struktur kontrol pengulangan untuk memahami hal ini. 8.5.3. Menggunakan Break dan Continue Pernyataan break memiliki tiga fungsi yaitu: • Menghentikan pemilihan pada pernyataan switch. • Menghentikan proses pengulangan atau keluar dari badan loop. • Keluar dari blok label tertentu. Pemakaian break pada pernyataan switch sudah kita pelajari pada struktur pemilihan. Kita akan pelajari sekarang bagaimana menggunakan break pada pengulangan. Perhatikan contoh berikut. Contoh 8.13. Penggunaan break pada pengulangan. class BreakPengulangan { public static void main(String[] args) { for (int i=0; i<10; i++) { if (i == 5) { break; } System.out.println("baris ke-" + i); } System.out.println("Ini setelah break pengulangan”); } } Pada contoh 8.13 seharusnya pengulangan akan terjadi sebanyak 10 kali (dimulai dari 0 sampai dengan 9). Tetapi, karena ada pernyataan if (1 == 5) {break;} maka pengulangan akan berhenti ketika nilai i =5. Kemudian Rekayasa Perangkat Lunak 185 alur program akan keluar dari badan dan menjalankan perintah setelah tanda akhir pengulangan. Pernyataan continue digunakan untuk memaksa melanjutkan proses pengulangan. Perhatikan contoh berikut. program untuk Contoh 8.14. Penggunaan continue. String nama[] = {"Joni", "Riko", "Denis", "Riko"}; int hitung = 0; for( int i=0; i using namespace std; Perhatikan kode program di samping ini. Kode program terdiri dari beberapa bagian seperti berikut: void nama_fungsi() { //kode untuk nama_fungsi .....; } - Bagian untuk mendaftarkan file atau kondisi tertentu. Bagian ini selalu diawali dengan tanda #. // Fungsi utama int main() { - Bagian pendefinisian fungsi. Diawali dengan kata kunci void diikuti nama fungsi. Bagian ini boleh tidak ada jika kita tidak membuat fungsi. // kode bagian main/utama .....; Bagian main(). Pada kode program biasanya dimulai dengan int main(). Bagian ini harus ada pada setiap program karena merupakan fungsi utama. return 0; } - - Bagian yang dimulai dengan tanda { dan diakhiri dengan tanda }, baik pada bagian void maupun main, disebut blok kode. 9.1.2. Header File (.h) File header yaitu file dengan ekstensi .h merupakan file yang berisi fungsifungsi dan telah dikompilasi sebelumnya. File ini biasanya berisi fungsi-fungsi tertentu yang nantinya akan kita gunakan dalam kode program yang kita buat. Sebagai contoh file iostream.h mempunyai sejumlah fungsi untuk menampilkan output dan menangkap input seperti cout dan cin. Ada dua model penulisan file header, yaitu dengan dituliskan lengkap dengan ekstensinya dan tidak. Bentuk pertama adalah model penulisan untuk compiler C++ lama (Contoh 9.1). Bentuk kedua merupakan bentuk yang didukung oleh Compiler C++ standar (Contoh 9.2). Contoh 9.1. Penulisan file header pada Compiler C++ lama. #include Int main() { ... return 0; } Contoh 9.2. Penulisan file header pada Compiler C++ standar. #include using namespace std; Int main() { ... 220 Rekayasa Perangkat Lunak return 0; } 9.1.3. Komentar, Identifier dan Tipe Data • Komentar Komentar pada C++ dapat dilakukan dengan dua cara, yaitu pertama, dengan tanda // dan diletakkan sebelum komentar dan kedua dengan tanda /* yang ditutup dengan */. Cara pertama digunakan jika komentar hanya terdiri dari satu baris, sedangkan cara kedua jika komentar lebih dari satu baris. Contoh 9.3. Komentar dengan tanda //. // program pertama #include int main( ){ cout << "Hello World"; // cetak “Hello World” di layar } Contoh 9.4. Komentar dengan tanda /* .. */.. /* Program pertama Ditulis oleh ARM Tanggal 17-11-2007 */ #include int main( ){ std::cout << "Hello World"; // cetak “Hello World” di layar } • Identifier Identifier atau nama dari variabel atau konstanta pada C++ secara umum sama mengikuti aturan umum penamaan yang telah dijelaskan pada Bab 5. Ada satu tambahan yang cukup penting dalam pembuatan identifier pada C++ yaitu, bersifat case sensitif. Variabel dengan nama namaguru berbeda dengan variabel NamaGuru. Ada dua cara untuk mendeklarasikan konstanta. Pertama, dengan menggunakan preprocessor directive #define. Kedua, dengan menggunakan kata kunci const. Ketiklah program berikut ini, kemudian periksalah hasil dari eksekusinya. Contoh 9.5. Pendeklarasian konstanta. #include #define potongan 0.1; using namespace std; int main() { const float hargaPerUnit = 2500; int jumlahUnit; Rekayasa Perangkat Lunak 221 float hargaTotal, hargaDiskon, diskon; cout << "Masukkan jumlah unit pembelian : "; cin >> jumlahUnit; hargaTotal = jumlahUnit * hargaPerUnit; diskon = hargaTotal * potongan; hargaDiskon = hargaTotal - diskon; cout << "Total harga pembelian = " << hargaTotal << endl; cout << "Diskon = " << diskon << endl; cout << "Harga Diskon = " << hargaDiskon; return 0; } Pada contoh di atas, terdapat dua konstanta yaitu potongan dan hargaPerUnit yang masing-masing dideklarasikan dengan cara berbeda. Deklarasi variabel dilakukan dengan cara menyebutkan lebih dahulu tipe datanya kemudian diikuti dengan nama variabelnya seperti pada contoh 9.5. Pada contoh tersebut ada beberapa variabel yang telah didefinisikan lebih dahulu yaitu jumlahUnit, hargaTotal, hargaDiskon dan diskon. Masingmasing dengan tipe datanya sendiri. Untuk beberapa variabel yang tipe datanya sama, kita dapat menggabungkan dalam satu baris dengan tanda pemisah koma. Perhatikan pada contoh di atas. hargaTotal, hargaDiskon dan diskon sama-sama mempunyai tipe data float sehingga penulisannya digabung. Kalian harus mendeklarasikan dengan lengkap seluruh variabel atau konstanta yang akan dipakai lebih dahulu sebelum menggunakan. Kalau tidak maka program tidak akan dapat dieksekusi. • Tipe data Seperti telah dijelaskan pada Bab 5, tipe data tergantung dari yang disediakan oleh bahasa pemrograman. Pada C++ tipe data dasar yang disediakan dapat dilihat pada tabel berikut. Kalau kalian perhatikan tipe-tipe ini sama persis dengan Java. Hal ini karena Java sebenarnya banyak mengambil elemen-elemen bahasa pemrograman dari C++. Tabel 9.1. Tipe data pada C++. Tipe Data int long float double char bool short 222 Keterangan Tipe data bilangan bulat dengan ukuran 4 bytes Tipe data bilangan bulat namun lebih besar dari int. Tipe data bilangan pecahan Tipe data bilangan pecahan namun lebih besar dari float Tipe data karakter yang berisi huruf, angka atau simbolsimbol (alphanumeric) sepanjang berada pada tanda “ “ atau ‘ ‘. Tipe data boolean Tipe data bilangan bulat dengan ukuran 2 bytes Rekayasa Perangkat Lunak Tipe data bentukan yang tersedia pada C++ adalah array, struct dan enum. Array akan kita bahas pada bagian lain di bab ini. Sedangkan struct dan enum telah kita singgung di Bab 5. Namun begitu cara penulisannya belum kita ulas. Cobalah ketikkan kode-kode program pada contoh berikut ini kemudian eksekusi untuk melihat hasilnya. Contoh 9.6. Penggunaan tipe data struct. #include using namespace std; int main() { struct Guru { char* NIP; char* Nama; char* Alamat; }; Guru A; A.NIP = "132 232 477"; A.Nama = "Syafiq"; A.Alamat = "Perum. Dirgantara Permai"; // Menampilkan nilai yang diisikan ke layar cout< using namespace std; enum JENIS_KELAMIN { Pria, Wanita }; int main() { struct Guru { char* NIP; char* Nama; JENIS_KELAMIN JK; } A; A.NIP = "132 232 477"; A.Nama = "Syafiq"; A.JK = Pria; cout<<"NIP cout<<"Nama : "< Lebih besar < Lebih kecil >= Lebih besar atau sama dengan <= Lebih kecil atau sama dengan == Sama dengan != Tidak sama dengan 224 Rekayasa Perangkat Lunak Contoh C=5 X = +10 Y = -12 ++C (pre-increment) C++ (post-increment) --C (pre-increment) C-- (post-increment) 3 7 5 6 5 +5=8 –2=5 * 2 = 10 /3=2 /2=1 1 && 1 = 1 1 || 0 = 1 !0 = 1 (5 (5 (4 (5 (5 (5 > 4) = 1 < 4) = 0 >= 4) = 1 <= 4) = 0 ==4) = 0 != 4) = 1 Operator Bitwise & | ^ ~ Operator Ternary ?: AND OR XOR NOT Digunakan operand 1&0=0 1|0=1 1^1=0 ~0 = 1 jika melibatkan tiga 9.1.5. Struktur Kontrol Program Struktur kontrol program pada C++ secara umum sama dengan VB dan Java yang telah kalian pelajari. Yang berbeda adalah sintaks penulisannya. Untuk percabangan, C++ menyediakan perintah if (tanpa then) dan switch ... case. Sedangkan untuk pengulangan, C++ menyediakan perintah for, while, dan do-while. Selain itu, pada pengulangan juga menyediakan fasilitas break dan continue. Secara berurutan berikut ini akan disampaikan kode-kode program untuk menerapkan struktur kendali. Ketikkan kode-kode tersebut, kemudian jalankan dan amati apa yang terjadi. Contoh 9.7. Penggunaan struktur percabangan if sederhana. #include using namespace std; int main() { int bil; cout<<"Masukkan sebuah bilangan bulat : "; cin>>bil; // Melakukan pengecekan bilangan dengan operator modulus if (bil % 2 == 0) { cout< using namespace std; Rekayasa Perangkat Lunak 225 int main() { int bil; cout<<"Masukkan sebuah bilangan bulat : "; cin>>bil; if (bil > 0) { cout< using namespace std; int main() { int bil; cout<<"Masukkan sebuah bilangan (1 s/d 5) : "; cin>>bil; switch (bil) { case 1 : cout<<"Bilangan anda adalah : SATU"; break; case 2 : cout<<"Bilangan anda adalah : DUA"; break; case 3 : cout<<"Bilangan anda adalah : TIGA"; break; case 4 : cout<<"Bilangan anda adalah : EMPAT"; break; case 5 : cout<<"Bilangan anda adalah : LIMA"; break; default : cout<<"Anda memasukkan di luar batas"; } return 0; } Contoh 9.9. adalah contoh percabangan dengan switch untuk konversi dari bilangan angka ke teks. Perhatikan bagaimana penulisan switch dan case. 226 Rekayasa Perangkat Lunak Seperti juga pada Java, pengulangan dengan for digunakan jika kita mengetahui dengan pasti berapa banyak pengulangan akan dilakukan. Berikut contoh penggunaan pengulangan dengan for. Contoh 9.10. Penggunaan struktur pengulangan dengan for. #include using namespace std; int main() { int C, J; cout<<"Cetak angka dari kecil ke besar :"<0; J--) { cout< using namespace std; int main() { for (int j=1; j<=4; j++) { for (int k=1; k<=3; k++) { cout< using namespace std; int main() { int C; C = 1; // inisialisasi nilai C while (C<10) { cout<<"Saya tidak nakal lagi"< using namespace std; int main() { int x, y; x = 1; //inisialisasi variabel x while (x<=4){ y = 1; //inisialisasi variabel y while (y<=3){ cout< using namespace std; int main() { int J = 5; int K; do { K = 1; do { cout<= 1); return 0; } Contoh 9.14 terlihat menampilkan kode program yang cukup rumit. Namun bila kita cermati, ini adalah kode program dengan pengulangan do while yang bersarang. Perhatikan cara penulisan dan alur logika programnya. Dowhile yang luar menggunakan variabel counter J dan ini adalah pengulangan dari besar ke kecil (perhatikan J diinisialisasi dengan nilai 10 dan syarat kondisi pada while J >=1). Sedangkan do-while yang dalam variabel counter nya adalah K dengan pengulangan dari kecil ke besar. Bagaimanakah hasil dari eksekusi kode program di atas? Perhatikan output di bawah ini. Cobalah untuk menelusuri kode program sehingga kalian benar-benar mengerti mengapa output program bisa menjadi seperti ini. 5 4 3 2 1 10 15 20 25 8 12 16 6 9 4 9.1.6. Input/Output Sampai dengan bagian ini, kalian telah cukup banyak latihan kode pemrograman C++. Namun kita belum sekalipun mempelajari statement input / output pada C++. Sebenarnya kalau kalian jeli, kalian telah secara tidak langsung mempelajari pernyataan input dan output. Perintah cout dan cin yang telah kalian gunakan adalah pernyataan input / output yang paling sering digunakan. Baik perintah cout dan cin digolongkan sebagai stream yang termasuk dalam kelas iostream. Karena itulah setiap kali kita ingin menggunakan dua perintah tersebut kita harus memanggil file header iostream di awal program. Rekayasa Perangkat Lunak 229 Stream adalah peralatan logika yang berguna untuk mendapatkan atau memberikan informasi. Stream berhubungan dengan perangkat keras seperti keyboard, layar monitor, printer melalui sistem I/O. Perintah cin merupakan stream untuk input standar. Perintah ini akan merekam apa yang kita ketikkan dari keyboard. Perhatikan cara penulisannya pada contoh 9.15. Contoh 9.15. Penggunaan cin dan cout. #include using namespace std; int main() { int bil1, bil2; //cin bagian satu cout<<"Masukkan bilangan pertama : "; cin>>bil1; cout<<"Masukkan bilangan kedua : "; cin>>bil2; cout<<"Hasil kali kedua bilangan = "<>bil1>>bil2; cout<<"Hasil kali kedua bilangan = "<>. Perintah cout adalah perintah melakukan output standar yaitu pada layar monitor. Perintah cout harus diikuti operator <<. Perhatikan contoh 9.15 di atas. cout dapat digunakan untuk mencetak langsung karakter (ditandai dengan “ dan diakhiri dengan “) atau isi variabel. Seperti halnya cin, cout dapat digunakan untuk output satu persatu atau berurutan sekaligus. Pada contoh di atas pernyataan endl adalah pernyataan untuk mencetak baris baru. 9.2. FUNGSI DALAM C++ Fungsi dalam C++ memegang peranan sangat penting. Hal ini karena sebenarnya program dalam C++ adalah kumpulan dari fungsi-fungsi. Fungsifungsi yang telah tersedia maupun yang kita buat sendiri ini akan dipanggil dalam fungsi utama yaitu main(). Seperti semua bahasa pemrograman, C++ menyediakan built-in function yang dapat diakses dengan lebih dulu memanggil file headernya di awal program yang kita buat. C++ juga menyediakan fasilitas 230 Rekayasa Perangkat Lunak untuk membuat fungsi sendiri (user-defined function). akan mempelajari bagaimana membuat fungsi sendiri. Pada sub bab ini kita 9.2.1. Tipe-tipe Fungsi Ada dua jenis fungsi, yaitu fungsi yang tidak mengembalikan nilai dan fungsi yang mengembalikan nilai. • Fungsi yang tidak mengembalikan nilai Fungsi ini dibuat dengan tipe void. Dalam VB atau Pascal, fungsi ini dikenal sebagai prosedur. Perhatikan contoh 9.16 berikut. Contoh 9.16. Fungsi tanpa pengembalian nilai. #include using namespace std; // Membuat fungsi cetak angka void CetakAngka() { for (int C=0; C<10; C++) { cout< Rekayasa Perangkat Lunak 231 using namespace std; // Membuat fungsi dengan nilai pengembalian tipe char char* NilaiChar() { return "Ini nilai yang akan dikembalikan"; } // Fungsi utama int main() { // Memanggil dan menampilkan hasil fungsi cout<< NilaiChar(); return 0; } Pada tipe fungsi ini, kita membutuhkan pernyataan return untuk menunjukkan bagian yang akan dikembalikan nilainya. Pada contoh di atas, tipe data dari nilai yang akan dikembalikan adalah char. Bentuk char dengan tanda * menunjukkan variabel NilaiChar boleh berisi lebih dari satu huruf dan akan disimpan/dicetak sebagaimana ketika kita memasukkan isinya. 9.2.2. Penggunaan Parameter dalam Fungsi Seperti halnya pada VB dan Java, fungsi pada C++ juga membolehkan digunakan parameter atau argumen untuk melewatkan input atau menampung output dari fungsi tersebut. Perhatikan contoh-contoh berikut. Contoh 9.18. Fungsi dengan parameter input. #include using namespace std; // Membuat fungsi dengan parameter input int Kuadrat(int X) { int hasil; hasil = X * X; return hasil; } int main() { int Bil, HASIL; cout<<"Masukkan sebuah bilangan bulat : "; cin>>Bil; HASIL = Kuadrat(Bil); //memanggil fungsi kuadrat cout<<"Kuadrat dari bilangan “< using namespace std; // Membuat fungsi dengan parameter input int Kuadrat(int X, int *hasil) { *hasil = X * X; return *hasil; } int main() { int Bil, HASIL; cout<<"Masukkan sebuah bilangan bulat : "; cin>>Bil; // Menampilkan nilai setelah diproses di dalam fungsi cout<<"Kuadrat dari bilanga "< using namespace std; Rekayasa Perangkat Lunak 233 int main() { long *Alamat; long X; Alamat = &X; X = 5; // Mengisikan nilai 5 ke dalam variabel X cout<<"Nilai cout<<"Nilai cout<<"Nilai cout<<"Nilai X : "< using namespace std; int main() { long *Alamat; long *Alamat1; Alamat = NULL; cout<<"Alamat memori yang ditunjuk dengan NULL : "< using namespace std; int main() { int *Alamat; // Melakukan alokasi memori Alamat = new int; // Menggunakan memori yang telah dialokasikan *Alamat = 100; cout<<"Nilai *Alamat : "<<*Alamat< using namespace std; int main() { // deklarasi array A dengan 5 buah elemen bertipe int int A[5]; cout<<"A[C]"<<" "<<"B"< using namespace std; int main() { // Deklarasikan dan inisialisasi array char X[3] = { 'A', 'B', 'C' }; // Menampilkan nilai awal elemen array cout<<"Nilai array awal"< using namespace std; class CPolygon { protected: int width, height; public: void set_values (int a, int b) { width=a; height=b;} }; class CRectangle: public CPolygon { public: int area () { return (width * height); } }; class CTriangle: public CPolygon { public: int area () { return (width * height / 2); } }; int main () { CRectangle rect; CTriangle trgl; rect.set_values (4,5); trgl.set_values (4,5); cout << rect.area() << endl; cout << trgl.area() << endl; return 0; } Pada kode program di atas, CPolygon adalah superclass, sedangkan CRectangle dan CTriangle adalah subclass. Pada kelas CPolygon, variabel width dan height dideklarasikan sebagai protected, karena ditujukan untuk bisa diakses oleh subclassnya saja. Selain itu kelas ini juga mempunyai method set_values. Kedua variabel dan method ini akan diwariskan pada subclassnya yaitu CRectangle dan CTriangle. Perhatikan bagaimana CRectangle dan CTriangle dideklarasikan sebagai kelas turunan dari CPolygon dengan menggunakan kata kunci public. Sekarang coba ganti kata public pada deklarasi kelas CTriangle sehingga menjadi class CTriangle: private CPolygon. Apabila kalian kompilasi maka kalian akan menjumpai pesan kesalahan sebagai berikut: Compiling source file(s)... oo-test.cpp oo-test.cpp: In function `int main()': oo-test.cpp:9: error: `void CPolygon::set_values(int, int)' is inaccessible oo-test.cpp:28: error: within this context Rekayasa Perangkat Lunak 243 oo-test.cpp:28: error: `CPolygon' is not an accessible base of `CTriangle' Mengapa kesalahan kompilasi bisa terjadi? Hal ini karena berlakunya aturan di atas. Method set_values pada kelas CPolygon dideklarasikan dengan public, tetapi diturunkan ke kelas CTriangle dengan private. Hal ini akan merubah method yang semula public menjadi private ketika berada pada kelas CTriangle. Tentunya kalian ingat bila anggota kelas diberi hak akses private maka dia tidak dapat diakses dari luar. 9.4.3. Polimorfisme Pada C++, untuk dapat menerapkan polimorfisme maka kita perlu menggunakan fungsi khusus yang dikenal sebagai fungsi virtual. Fungsi ini kita letakkan pada superclass, kemudian fungsi tersebut dapat kita definisikan ulang pada subclass. Perhatikan contoh berikut. Contoh 9.29. Penggunaan fungsi virtual. #include using namespace std; class AnggotaSekolah { char* nama; char* alamat; public: void SetNama(char* N) { nama = N; } void SetAlamat(char* A) { alamat = A; } char* GetNama() { return nama; } char* GetAlamat() { return alamat; } // Membuat fungsi virtual virtual void Bekerja() { cout<<"Bekerja"< using namespace std; class CPolygon { protected: int width, height; public: void set_values (int a, int b) { width=a; height=b; } virtual int area (void) =0; //fungsi virtual murni void printarea (void) { cout << this->area() << endl; } }; class CRectangle: public CPolygon { public: // overriding fungsi area int area (void) { return (width * height); } Rekayasa Perangkat Lunak 247 }; class CTriangle: public CPolygon { public: // overriding fungsi area int area (void) { return (width * height / 2); } }; int main () { CRectangle rect; CTriangle trgl; CPolygon *ppoly1 = ▭ pointer CPolygon *ppoly2 = &trgl; pointer ppoly1->set_values (4,5); ppoly2->set_values (4,5); ppoly1->printarea(); ppoly2->printarea(); return 0; } // mendefinisikan obyek // mendefinisikan obyek Pada contoh di atas, kela CPolygon adalah kelas abstrak yang memiliki fungsi virtual murni yaitu area. Perhatikan cara mendeklarasikan fungsi virtual murni pada baris yang diawali dengan pernyataan virtual. Fungsi ini tidak dibuat isinya tapi dibuat dengan tanda = 0. Kita tidak dapat membuat obyek langsung dari kelas CPolygon ini. Tetapi kita dapat membuat obyek pointer untuk mengalokasikan memori berdasarkan kelas ini. Pada kelas CPolygon juga digunakan kata kunci this. Kata kunci ini berfungsi untuk menunjuk pada kelas itu sediri. Pernyataan this->area() pada kode di atas sama artinya dengan CPolygon->area(). Jadi pernyataan ini sama artinya dengan memanggil fungsi virtual area di dalam kelas itu. Pada kode diatas dibuat dua variabel pointer *ppoly1 dan *ppoly2 yang nilainya sama dengan nilai dari alamat variabel rect dan trgl. Perhatikan dengan baik penggunaan tanda * dan & untuk merujuk pada alamat memori. Jalankan program di atas dan perhatikan hasilnya. 9.5. MERANCANG APLIKASI BERORIENTASI OBYEK Konsep dasar tentang pemrograman berorientasi obyek telah kalian pelajari pada Bab 8. Sedangkan penerapannya dalam bahasa pemroraman juga telah kalian pelajari dengan menggunakan Java pada bab 8 dan C++ di bab ini. Pada bagian ini kita akan mencoba untuk membuat rancangan aplikasi berorientasi obyek. Kasus yang kita angkat adalah salah satu bagian dari aplikasi penjualan pada toko buku, yaitu persediaan barang. Jika kalian cermati ada banyak jenis barang yang dijual pada sebuah toko buku, antara lain buku-buku bacaan, 248 Rekayasa Perangkat Lunak majalah, alat tulis kantor, dan lain-lain. Masing-masing barang mempunyai nama merek, harga, dan karakteristik yang lain. Selain itu masing-masing barang juga mempunyai ketentuan-ketentuan lain yang berhubungan dengan penetapan harga, potongan, jumlah pembelian dan tempat penyimpanan. Persediaan barang pada took buku ditentukan oleh barang yang masuk dari hasil pemesanan dan barang yang keluar karena terjual. Setiap barang keluar maka secara otomatis barang di dalam persediaan akan berkurang. Langkah awal dalam aplikasi berorientasi obyek adalah dengan melakukan abstraksi pada permasalahan. Kalau kita perhatikan dengan seksama pada kasus di atas, kita bisa membuat kelas induk dari semua jenis barang yang ada. Hal ini karena selain karakteristik khusus dari masing-masing jenis barang, juga ada karakteristik umum yang dipunyai oleh semua barang. Seperti contoh harga adalah karakteristik umum yang dipunyai oleh semua barang. Tetapi merek adalah khusus pada jenis item barang tertentu, terutama pada alat tulis. Demikian juga dengan karakteristi judul hanya dimiliki oleh buku bacaan. Dengan melihat kondisi tersebut kita dapat membuat abstraksi permasalahan sebagai berikut. Gambar 9.10. Abstraksi kasus persediaan barang di toko buku. Rekayasa Perangkat Lunak 249 Pada Gambar 9.10, kita membentuk 6 kelas untuk mempermudah kasus di atas. Ada dua macam hubungan yang terbentuk pada gambar di atas, yaitu hubungan pewarisan (inheritance) yang ditandai dengan tanda panah dan asosiasi (hubungan antara dua atau lebih kelas) yang ditandai garis tanpa tanda panah. Barang adalah superclass dan bisa kita nyatakan sebagai kelas abstrak. BahanBacaan dan AlatTulis adalah subclass dari Barang, sedangkan Buku dan Majalah adalah subclass dari BahanBacaan. Sedangkan Lokasi merupakan kelas yang menunjukkan tempat menyimpan barang. Pada kasus di atas kita dapat menerapkan konsep inheritance dan polimorfisme serta menggunakan fungsi virtual murni pada kelas Barang. Kemudian fungsi-fungsi ini dapat kita turunkan untuk diimplementasikan pada subclass-subclassnya. Rancangan kode program akan tampak seperti pada table 9.3. Dengan melihat diagram dan tabel 9.3, kita dapat menerapkan dalam kode program. Akan ada 6 kelas yang kita buat kodenya. Masing-masing kelas bisa dalam satu file sendiri-sendiri atau semua kelas bisa kita letakkan dalam satu file. Kemudian implementasi dari class-class tersebut kita buat dalam satu file tersendiri. Untuk menghubungkan antar file dan memanggil class pada file lain kita menggunakan preprocessor #include diikuti dengan nama filenya. Tabel 9.3. Kelas, fungsi, dan parameter pada aplikasi persediaan toko buku. Nama Kelas Variabel Fungsi Parameter Keterangan Barang KodeBrg - SisaBarang - Simpan Kelas Abstrak BahanBacaan Harga SediaanAwal BrgKeluar BrgMasuk Penerbit pAwal, bKeluar, bMasuk kodeLok ISBN Judul Pengarang Tahun JumlahHalaman Diskon Nama NoEdisi TglTerbit - setDiskon - getDiskon - HrgDiskon Buku Majalah AlatTulis 250 Supplier Rekayasa Perangkat Lunak Hrg, Potongan Subclass dan mewarisi anggota kelas Barang Subclass dari BahanBacaan dan mewarisi anggota kelas tersebut Subclass dari BahanBacaan dan mewarisi anggota kelas tersebut Subclass dari Nama Merek Lokasi 9.6. KodeLokasi Deskripsi setKodeLok getKodeLok BahanBacaan dan mewarisi anggota kelas tersebut Kelas yang berasosiasi dengan kelas Barang RINGKASAN • Struktur umum program dalam C++ meliputi bagian pendaftaran file, pendefinisian fungsi, bagian main(), dan blok kode. • Tipe data primitive pada C++ terdiri dari int, long, float, double, char, bool, dan short. Tipe data composite yang disediakan adalah struct, enum dan array. • Tipe-tipe operator yang dapat digunakan adalah operator assignment, operator unary, operator binary, operator relasional, operator bitwise dan operator ternary. • Struktur control pemilihan dapat dilakukan dengan if (tanpa then) dan switch ... case. Sedangkan untuk pengulangan, C++ menyediakan perintah for, while, dan do-while. • Pernyataan input dan output dapat dilakukan dengan perintah cout dan cin sebagai stream yang termasuk dalam kelas iostream. • Fungsi dapat tidak mengembalikan nilai tetapi juga dapat mengembalikan nilai. Parameter pada fungsi dapat berupa parameter input, parameter output atau dua-duanya. • Pointer adalah variabel. Namun berbeda dengan variabel normal, pointer menyimpan alamat pada memori, bukan nilai yang kita masukkan. • C++ mendukung konsep pemrograman berorientasi obyek melalui pembuatan kelas, inheritance, fungsi virtual, overriding, overloading dan polimorfisme. Rekayasa Perangkat Lunak 251 9.7. SOAL-SOAL LATIHAN 1. Buatlah program C++ untuk mencari rata-rata 5 buah bilangan 34, 56, 91,11, 22. 2. Buatlah program menggunakan C++ untuk menentukan harga barang setelah di diskon dengan tampilan sbb: Masukkan harga barang/unit : Rp. 20000 Jumlah barang yang dibeli : 5 ---------------------------------------------Total Harga sebelum diskon : Rp. 100000 Diskon (10%) : Rp. 10000 ------------------ Harga bersih : Rp. 90000 3. Seseorang punya rekening tabungan di bank sebesar Rp. 10.000,- (saldo awal). Selanjutnya ia dapat menyetor atau mengambil tabungannya. Buatlah program dengan C++ untuk keperluan transaksi di bank tsb. Tampilan menu utamanya sbb: -------------------------------------PT. BANK ABC -------------------------------------Saldo : .... Menu Transaksi 1. Setor Tabungan 2. Ambil Tabungan 3. Exit Pilihan menu (1/2/3) ? ... Ketentuan: Bank membuat kebijakan bahwa saldo minimum yang harus disisakan di rekening adalah Rp. 10.000,Jika nasabah memasukkan angka 1 maka dia akan diminta memasukkan jumlah rupiah yang akan disetor. Jika nasabah memilih angka 2 maka nasabah diminta memasukkan jumlah rupiah yang akan ditarik. Jika jumlah penarikkan mengakibatkan saldo kurang dari Rp. 10000 maka program akan menolak. (Petunjuk: gunakan pernyataan cin untuk mendapatkan input dari keyboard) 4. Buatlah program menggunakan function untuk menentukan nilai akhir suatu pelajaran. Terdapat 2 argumen function yaitu nilai ujian tengah semester dan nilai ujian akhir semester. Output yang diinginkan adalah jika nilai rata-rata lebih besar atau sama dengan 80 maka nilai akhirnya adalah A, jika nilai rata-rata kurang dari 80 dan lebih besar sama dengan 70 maka nilainya B, jika kurang dari 70 maka nilainya C. 5. Perhatikan contoh soal pada Bab 8 no 6. Buatlah diagram abstraksi sistemnya kemudian buatlah kode programnya dengan menggunakan bahasa C++. 252 Rekayasa Perangkat Lunak BAB 10 DASAR-DASAR SISTEM BASIS DATA Gambar di samping ini adalah gambar sebuah pesawat telepon seluler atau lebih dikenal sebagai handphone yang sedang menjalankan salah satu aplikasi yaitu Contact List. Mungkin aplikasi seperti pada gambar ini tidak asing bagi kalian yang pernah menggunakan handphone. Aplikasi ini menyimpan nama teman, orang tua atau yang lainnya lengkap dengan nama dan nomor teleponnya. Bahkan kadang-kadang dilengkapi dengan alamat email, alamat kantor, nomor fax dan data-data lainnya. Gambar 10.1. Fasilitas contact list pada pesawat telepon seluler. Perhatikan aplikasi Contact List ini. Ketika kalian memasukkan nama dan nomor telepon seseorang maka nama dan nomor telepon tersebut tidak akan tertukar dengan nama atau nomor telepon orang lain. Semuanya teratur rapi. Kalian juga bisa mencari nama orang tertentu hanya dengan mengetikkan beberapa huruf yang ada hubungannya dengan nama. Perhatikan juga bahwa nama yang tersimpan selalu urut abjad, meskipun anda memasukkannya tidak berdasarkan urutan. Data nama, nomor telepon dan data-data lainnya pada aplikasi Contact List disusun berdasarkan konsep pengaturan data yang lebih dikenal sebagai basis data. Pada bab ini kita akan mempelajari konsep-konsep dasar basis data. Kompetensi dasar sistem manajemen basis data (DBMS) merupakan bagian dari standar kompetensi membuat aplikasi berbasis Microsoft Access yang akan dibahas detil pada Bab 11. Bagian akhir dari bab ini akan ditutup dengan ringkasan dan latihan soal. Rekayasa Perangkat Lunak 253 TUJUAN Setelah mempelajari bab ini diharapkan pembaca akan mampu : o Menjelaskan pengertian data, basis data dan sistem manajemen basis data (DBMS) o Menjelaskan Entity-Relationship Diagram o Menjelaskan basis data relasional 10.1. DATA, BASIS DATA DAN SISTEM MANAJEMEN BASIS DATA 10.1.1.Basis Data Basis data (database) merupakan kumpulan dari data yang saling berhubungan satu dengan yang lainnya, tersimpan dalam perangkat keras komputer dan digunakan perangkat lunak untuk memanipulasinya. Basis data merupakan salah satu komponen utama dalam sistem informasi, karena merupakan basis dalam penyediaan informasi bagi para pemakai (Fathansyah, 1999; Post, 1999). Jika dibayangkan, basis data mirip dengan lemari di ruang administrasi sekolah yang menyimpan berbagai arsip. Masing-masing jenis arsip dikelompokkan, diatur dan disimpan pada tempat yang telah ditentukan. Sehingga akan ada kelompok arsip siswa, arsip guru, arsip mata pelajaran, arsip keuangan, dan lain-lain. Perbedaannya hanya pada media penyimpanannya. Kalau lemari arsip menggunakan lemari dari kayu, besi atau plastik, sedangkan basis data menggunakan media penyimpan elektronis seperti disk (hard disc, CD, atau tape). Gambar 10.2 memberikan ilustrasi tentang kesamaan lemari arsip dan basis data. Satu hal penting yang harus diperhatikan, basis data bukan hanya sekedar penyimpanan data secara elektronis. Tidak semua penyimpanan data elektronis bisa disebut basis data. Apabila penyimpanan itu tidak menggunakan prinsip pengaturan, pemisahan atau pengorganisasian maka kita tidak dapat menyebut penyimpanan data tersebut sebagai basis data. Pada Gambar 10.2 terlihat penerapan prinsip pengaturan, pengorganisasian atau pemisahan, baik pada lemari arsip atau pada basis data. 254 Rekayasa Perangkat Lunak Arsip Siswa Arsip Guru Arsip Keuangan Data Guru Basis Data Dalam Media Penyimpanan Data Siswa Data Keuangan Gambar 10.2. Lemari arsip dan basis data. Prinsip utama dalam basis data adalah konsep independensi data yaitu pemisahan data dari program aplikasinya (Lewis et al., 2002; Post, 1999). Sedangkan tujuan utama dalam basis data adalah membantu pengguna dalam abstraksi suatu sistem. Ada tiga level abstraksi yang biasanya digunakan yaitu physical level, conceptual level dan view level (Gambar 10.3). Physical level menunjukkan bagaimana data akan disimpan. Conceptual level berkaitan dengan data apa yang akan disimpan dan bagaimana hubungan antar data tersebut. View level merupakan level tertinggi yang menjelaskan bagian-bagian basis data pada pengguna tertentu (Ramakrishnan and Gehrke, 2000). Rekayasa Perangkat Lunak 255 User 1 User 2 User 3 View 1 View 2 View 3 Conceptual Level Physical Level Gambar 10.3. Tingkatan dalam abstaksi data (Lewis et al., 2002). Basis data mempunyai beberapa kriteria penting, yaitu : 1. Bersifat data oriented dan bukan program oriented. 2. Dapat digunakan oleh beberapa program aplikasi tanpa perlu mengubah basis datanya. 3. Dapat dikembangkan dengan mudah, baik volume maupun strukturnya. 4. Dapat memenuhi kebutuhan sistem-sistem baru secara mudah 5. Dapat digunakan dengan cara-cara yang berbeda. Secara bertingkat, operasi dasar basis data dapat digambarkan dalam skema pada Gambar 10.4. Operasi-operasi tersebut meliputi: - Pembuatan basis data baru (create database). Operasi ini sama dengan pembuatan atau pembelian lemari arsip yang baru. - Penghapusan basis data (drop database). Operasi ini sama dengan pengrusakan atau penghancuran lemari arsip. - Pembuatan tabel baru (create table). Operasi ini sama dengan penambahan kelompok arsip baru. Operasi ini baru bisa dijalankan jika basis data telah dibuat. - Penghapusan tabel (drop table). Operasi ini sama dengan pengrusakan kelompok arsip lama. Operasi ini baru bisa dijalankan jika tabel telah ada pada suatu basis data. 256 Rekayasa Perangkat Lunak Gambar 10. 4. Operasi-operasi dasar pada basis data. - Pengisian atau penambahan data baru (insert data) pada suatu tabel. Operasi ini mirip dengan penambahan lembaran arsip baru pada kelompok arsip. Operasi ini baru bias dijalankan jika tabel telah dibuat. - Pengambilan data dari suatu tabel (retrieve data). Operasi ini mirip dengan pencarian lembaran arsip yang tersimpan dalam kelompok arsip. - Pengubahan data dari suatu tabel (update data). Operasi ini mirip dengan perbaikan isi lembaran arsip dari suatu kelompok arsip - Penghapusan data dari suatu tabel (delete). Operasi ini mirip dengan penghapusan sebuah lembaran arsip dari suatu kelompok arsip. Basis data dibangun untuk memenuhi tujuan dalam pengorganisasian data, yang antara lain sebagai berikut : 1. Efisiensi meliputi kecepatan (speed), ruang simpan (space) dan keakuratan (accuracy). 2. Menangani data dalam jumlah besar. 3. Kebersamaan pemakaian (Shareability). 4. Meniadakan duplikasi dan inkonsistensi data. 10.1.2.Sistem Manajemen Basis Data Pengelolaan basis data secara fisik tidak dilakukan oleh pemakai secara langsung, tetapi ditangani oleh sebuah Perangkat Lunak yang khusus/spesifik. Perangkat lunak inilah disebut DBMS yang akan menentukan bagaimana data diorganisasi, disimpan, diubah dan diambil kembali. Ia juga menerapkan Rekayasa Perangkat Lunak 257 mekanisme pengaman data, pemakaian data secara bersama, pemaksaan keakuratan/konsistensi data, sebagainya. Secara ringkas struktur suatu DBMS dapat dilihat pada Gambar 10.5. Gambar 10.5. Struktur umum DBMS. Aplikasi-aplikasi tambahan bersifat opsional (bisa ada dan bisa tidak) dan biasanya terdapat pada DBMS sebagai fungsi tambahan. Sebagai contoh, aplikasi pembuat report (laporan), aplikasi untuk mendisain form, aplikasi untuk membuat diagram atau chart, aplikasi untuk monitoring sistem, dan aplikasiaplikasi lainnya. Ada puluhan bahkan mungkin ratusan perangkat lunak DBMS tersedia. Masing-masing dengan spesifikasinya sendiri-sendiri. Mulai dari sangat sederhana sampai yang paling kompleks. Pada bagian ini kita membahas 5 buah DBMS yang cukup familiar dikalangan pengguna DBMS, Microsoft Access, MySQL, Microsoft SQL Server, PosgreSQL, dan Oracle. x Microsoft Access Gambar 10.6. Logo MS Access Microsoft Access atau kadang disebut juga Microsoft Office Access adalah DBMS relational keluaran dari Microsoft yang termasuk dalam paket Microsoft Office. Microsoft Access mengkombinasikan engine relational Microsoft Jet Database, Graphical User Interface (GUI) dan perangkat pengembang perangkat lunak. Microsoft Access dapat menggunakan data yang disimpan dalam Microsoft Jet Database, Microsoft SQL Server, Oracle atau tipe lain asal kompatibel dengan ODBC (Open Database Connectivity). Microsoft 258 yang yang akan yaitu Rekayasa Perangkat Lunak Access seringkali digunakan dalam pengembangan aplikasi secara cepat (Rapid Application Development), terutama untuk membangun prototipe dan aplikasi stand-alone. Microsoft Access juga dapat digunakan sebagai basis data untuk aplikasi berbasis web sederhana. Namun pada aplikasi yang lebih kompleks, baik berdasarkan web atau tidak, Microsoft Access bukanlah pilihan yang baik. Terutama karena kekurangannya dalam menangani penggunaan oleh banyak pengguna (multi-user). Hal ini karena sebenarnya Microsoft Access adalah sebuah basis data personal yang lebih ditujukan untuk single-user. Microsoft Access juga tidak dilengkapi dengan database triggers dan stored procedurs. Gambar 10.7. Tampilan Microsoft Access. Salah satu keuntungan dari Microsoft Access bagi programmer adalah kompatibilitasnya terhadap SQL (structured query language) relatif tinggi. Pada Microsoft Access kita dapat membuat query berbasis teks atau berbasis GUI kemudian dapat langsung dieksekusi dengan mudah untuk mendapatkan hasil. x MyQSL Gambar 10.8. Logo MySQL MySQL adalah SQL-DBMS yang bersifat multi-user dan multi-threaded. MySQL berjalan sebagai server yang melayani banyak pengguna untuk mengakses sejumlah basis data. DBMS ini sangat populer di dunia aplikasi berbasis web sebagai komponen basis data. Selain karena tersedia dalam versi gratis, popularitas MySQL juga sangat dipengaruhi oleh populernya web server Apache dan bahasa pemrograman PHP. Istilah-istilah seperti LAMP (LinuxApache-MySQL-PHP/Perl/Python), MAMP (Mac-ApacheMySQL-PHP/Perl/Python dan WAMP (Windows-ApacheMySQL-PHP/Perl/Python menjadi sangat terkenal. Banyak Rekayasa Perangkat Lunak 259 sekali aplikasi berbasis web yang dibangun dengan menggunakan kombinasi perangkat lunak tersebut. WordPress, Drupal, Mambo, Wikipedia, PHP-Nuke, merupakan beberapa contoh aplikasi berbasis web yang menggunakan kombinasi ini. Tidak seperti Microsoft Access, default instalasi MySQL tidak menyediakan GUI bagi pengguna untuk berinteraksi dengan basis data. Pengguna dapat berinteraksi dengan client yang menggunakan perintahperintah berbasis teks. Namun saat ini telah banyak GUI yang dikembangkan untuk mempermudah interaksi dengan basis data, baik itu berupa aplikasi stand-alone (misalnya MySQL-Front, MySQL-GUI, dan lain-lain) atau yang berbasis web (misalnya, phpMyAdmin). Bahkan dengan menggunakan komponen MyODBC, MySQL dapat diakses dengan GUI dari Microsoft Access seperti halnya basis data yang kompatibel dengan ODBC lainnya. Gambar 10.9. Tampilan awal phpMyAdmin. x Microsoft SQL Server Gambar 10.10. Logo Microsoft SQL Server 260 Microsoft SQL Server adalah DBMS relational keluaran dari Microsoft seperti halnya Microsoft Access. Bahasa query utama yang digunakan adalah varian dari ANSI SQL yang disebut sebagai T-SQL (Transact-SQL). Bahasa ini membolehkan pengguna untuk membuat stored procedure sehingga meningkatkan efisiensi akses ke basis data. DBMS ini juga dilengkapi dengan fasilitas clustering dan mirroring. Cluster adalah kumpulan dari server-server yang konfigurasinya identik sehingga memungkinkan Sedangkan fasilitas pembagian kerja antar server. Rekayasa Perangkat Lunak mirroring membolehkan suatu DBMS untuk membuat tiruan (replika) dari isi basis data secara lengkap untuk digunakan pada server yang lain. Microsoft SQL Server tersedia dalam beberapa versi distribusi. Pada Microsoft SQL Server yang didistribusikan bersama Microsoft Office atau Microsoft Visual Studio, biasa disebut MSDE (Microsoft SQL Server Database Engine), tidak dilengkapi dengan perangkat GUI. Pengguna dapat melakukan interaksi dengan menggunakan client berbasis perintah teks seperti halnya MySQL. Sedangkan pada versi yang lebih tinggi seperti versi personal atau profesional telah tersedia fasilitas GUI (Gambar 10.11). Gambar 10.11. GUI pada Microsoft SQL Server x PostgreSQL Gambar 10.12. Logo PostgreSQL PostgreSQL atau sering disebut Postgres termasuk dalam kategori Object-Relational Database Management System (ORDBMS). ORDBMS adalah DBMS yang selain menggunakan prinsip-prinsip basis data relational juga menggunakan pendekatan berorientasi obyek dalam model basis datanya. Postgres dikembangkan sebagai freesoftware dan bersifat terbuka (open-source) sehingga tidak dikendalikan oleh satu atau dua perusahaan. Kelebihan Postgres dibandingkan DBMS lainnya Rekayasa Perangkat Lunak 261 adalah, sifatnya yang free dan open-source, dukungan dokumentasinya yang luar biasa, fleksibilitasnya dan fiturfiturnya yang tidak kalah dengan DBMS komersial. Selain mendukung model data object-relational, Postgres juga mendukung penggunaan basis data spasial (biasanya untuk penggunaan Sistem Informasi Geografis). Postgres juga mendukung operasi multi-user dan multi-threaded, bahkan mungkin lebih bagus dari MySQL dari sisi keamanan. Seperti halnya MySQL dan Microsoft SQL Server, kita dapat berinteraksi dengan basis data pada Postgres menggunakan perintah-perintah disisi klien dengan tool yang disebut psql. Antar muka yang bersifat GUI juga telah banyak dikembangkan, diantaranya phpPgAdmin, PgAdmin, dan lain-lain. x Oracle Database Gambar 10.13. Logo Oracle Nama Oracle Database atau Oracle RDBMS adalah nama yang sangat diperhitungkan dalam dunia DBMS. Oracle dikembangkan oleh Oracle Corporation. Oracle menyimpan data secara logika dalam bentuk tablespaces dan secara fisik dalam bentuk file-file data. Tablespaces dapat berisi berbagai macam bagian memori, misalnya bagian data, bagian index dan lain sebagainya. Bagian-bagian ini berisi satu atau lebih area. Area-area ini berisi kumpulan blok data yang berdekatan. Oracle dapat menyimpan dan store procedure dan fungsi secara mandiri. 10.2. ENTITY-RELATIONSHIP DIAGRAM Model E-R biasa digambarkan dalam bentuk diagram yang disebut ERD merupakan notasi grafis dalam pemodelan data konseptual yang digunakan untuk memodelkan struktur data dan hubungan antar data. Dengan ERD kita dapat menguji model dengan mengabaikan proses yang harus dilakukan. Dan dengan ERD kita mencoba menjawab pertanyaan seperti; data apa yang kita perlukan? bagaimana data yang satu berhubungan dengan yang lain? ERD menggunakan sejumlah notasi dan simbol untuk menggambarkan struktur dan hubungan antar data, pada dasarnya ada 3 macam simbol yang digunakan yaitu : Entity-Relationship Diagram (ERD). 1. Entitas : Entitas digambarkan dalam bentuk persegi empat. Gambar 10.14. Notasi entitas pada ER-Diagram 262 Rekayasa Perangkat Lunak 2. Atribut : Atribut digambarkan dalam bentuk ellips dan dihubungkan dengan entitas dimana atribut tersebut berada. Gambar 10.15. Penggunaan notasi atribut pada ER-Diagram. 3. Relationship: Relationship digambarkan dalam bentuk intan/diamonds. Gambar 10.16. Penggunaan notasi relationship pada ER-Diagram. 10.2.1.Entitas Entitas adalah individu yang mewakili sesuatu yang nyata (eksistensinya) dan dapat dibedakan dari sesuatu yang lain. Dapat berupa suatu elemen dari suatu lingkungan, suatu sumber daya atau sebuah transaksi yang memiliki arti penting bagi suatu model yang akan dibangun. Contoh Entitas set : o Semua Guru atau Guru saja. Himpunan ini memiliki anggota : Bapak Fahri, Ibu Fitri, Bapak Joko dan guru-guru yang lain. o Semua Siswa atau Siswa saja. Himpunan ini memiliki anggota : Joni, Ridho, Fanny, Donny dan siswa-siswa yang lain. o Semua Mobil atau Mobil saja. Rekayasa Perangkat Lunak 263 Himpunan ini memiliki anggota : mobil Daihatsu, mobil Toyota, mobil Suzuki, dan mobil-mobil yang lain. Mengidentifikasi ada atau tidaknya entitas dalam suatu masalah memang tidak mudah. Tapi biasanya apabila kita menjumpai kata benda dalam permasalahan tersebut maka kata tersebut biasanya merupakan kandidat entitas. Sebagai contoh bila kita akan membangun basis data perpustakaan sekolah, maka kita akan menjumpai buku, siswa, guru, petugas perpustakaan sebagai calon kuat entitas. 10.2.2.Atribut Setiap entitas mempunyai atribut. Atribut adalah karakteristik atau ciri yang membedakan antara entitas satu dengan entitas yang lainnya. Contoh Atribut : o Entitas Siswa. Memiliki atribut antara lain: nis (nomor induk siswa), nama, alamat, nomor telepon, tempat lahir, tanggal lahir dan lain-lain. Gambar 10.17. Entitas siswa dan atributnya. o Entitas Guru. Memiliki atribut antara lain: NIP, nama, alamat, pangkat, nomor telepon, tempat lahir, tanggal lahir, bidang keahlian, dan lain-lain. 264 Rekayasa Perangkat Lunak Gambar 10.18. Entitas guru dan atributnya. o Entitas Mobil. Memiliki atribut antara lain: Nomor mesin, nomor rangka, warna, tahun keluar, tipe mesin, bahan baker, dan lain-lain. Gambar 10.19. Entitas mobil dan atributnya. Tidak semua karakteristik dari entitas penting bagi suatu ruang lingkup masalah. Sebagai contoh pada masalah basis data perpustakaan, karakteristik nomor sepatu siswa bukanlah karakteristik yang penting yang dapat dijadikan sebagai atribut. Tetapi apabila ruang lingkup masalahnya adalah basis data pemesanan seragam sepatu siswa, maka nomor sepatu adalah atribut yang penting. Rekayasa Perangkat Lunak 265 Selain memilih mana yang benar-benar penting bagi sebuah entitas, kita juga harus menentukan mana yang akan menjadi atribut kunci (Primary Key). Pada contoh di atas (contoh atribut) kita dapat dengan mudah menentukan primary key dari entitas yang ada. Contoh Atribut kunci (Primary key). : o Entitas Siswa. Misalkan atribut yang dimiliki adalah : NIS (nomor induk siswa), nama, alamat, nomor telepon, tempat lahir, dan tanggal lahir. Dari keenam atribut ini, maka yang paling cocok menjadi primary key adalah NIS karena atribut ini yang paling unik. Tidak ada siswa yang memiliki NIS yang sama. Nama masih mungkin sama, tapi NIS tidak. o Entitas Guru. Misalkan atribut yang dimiliki adalah: NIP, nama, alamat, pangkat, nomor telepon, tempat lahir, tanggal lahir, dan bidang keahlian. Atribut yang paling cocok menjadi primary key adalah NIP karena atribut ini yang paling unik. Tidak ada guru yang memiliki NIP yang sama. Sehingga NIP dapat dijadikan pengidentifikasi entitas guru. o Entitas Mobil. Misalkan atribut yang dimiliki adalah: Nomor mesin, nomor rangka, warna, tahun keluar, tipe mesin, dan bahan baker. Di sini ada dua atribut yang unik yaitu nomor mesin dan nomor rangka. Pada kasus ini kita dapat memilih salah satu dari kedua atribut tersebut sebagai primary key. Sebagai panduan, berikut ini merupakan cirri-ciri dari atribut yang dapat dipertimbangkan sebagai identifier (candidate key) : o Niliainya tidak berubah-ubah o Tidak mungkin berisi nilai null (kosong bukan nol) o Tidak berisi data nama atau lokasi yang mungkin berubah-ubah. 10.2.3.Relationship Relationship atau relasi adalah hubungan yang terjadi antara sejumlah Misalkan dari entitas siswa ada seorang siswa yang memiliki NIS = “GHI007” dan nama_siswa = “Donny” mempunyai relasi dengan entitas program keahlian dengan kode_program = “RPL” dan nama_program = “Rekayasa Perangkat Lunak”. Relasi di antara kedua entitas mengandung arti siswa entitas. tersebut sedang mengambil program keahlian tersebut pada sekolah tertentu. 266 Rekayasa Perangkat Lunak Gambar 10.20. Relationship. Ramakrishnan and Gehrke (2000) menyebutkan bahwa konsep relationship pada model E-R berbeda dengan konsep relation di dalam model data relasional. Relationship adalah mekanisme yang menghubungkan antara entitas. Dalam implementasi ke dalam DBMS baik entitas maupun relationship akan direpresentasikan dalam bentuk tabel (relation). Setiap relationship selalu mempunyai kardinalitas. Kardinalitas atau Derajat Relasi menunjukkan jumlah maksimum entitas yang dapat berelasi dengan entitas lain pada himpunan entitas yang lain. Pada gambar 10.20 kita sebenarnya dapat melihat sebuah kardinalitas antara himpunan entitas siswa dengan himpunan entitas program keahlian. Siswa dapat berelasi hanya dengan satu entitas pada himpunan entitas program keahlian. Sebaliknya satu entitas pada program keahlian dapat berelasi dengan banyak siswa. Pada gambar tersebut terlihat Donny hanya dapat berhubungan dengan Rekayasa Perangkat Lunak, sedangkan Rekayasa Perangkat Lunak dapat berhubungan dengan Donny dan Joni. Ada beberapa jenis tingkat hubungan (kardinalitas) antara entitas satu dengan entitas lainnya. Kardinalitas menunjukkan jumlah maksimum entitas pada suatu himpunan entitas yang dapat berelasi dengan entitas pada himpunan entitas yang lain. Secara umum ada tiga bentuk kardinalitas antar himpunan entitas, yaitu : o satu ke satu (one to one). Hubungan dengan kardinalitas one-to-one artinya satu anggota suatu entitas set hanya boleh berhubungan dengan satu anggota entitas set yang lain. Hubungan antara entitas set suami dengan istri dapat dikelompokkan dalam hubungan one-to-one.’ Rekayasa Perangkat Lunak 267 Gambar 10.21. Hubungan one-to-one suami dan istri. o satu ke banyak / banyak ke satu (one to many / many to one). Kardinalitas satu ke banyak dan banyak ke satu dapat dianggap sama karena tinjauan kardinalitas selalu dilihat dari dua sisi. Contohnya adalah pada suatu sekolah mempunyai aturan satu kelas terdiri dari banyak siswa tetapi tidak sebaliknya, yaitu satu siswa tidak dapat belajar pada kelas yang berbeda. Gambar 10.22. Hubungan one-to-many kelas dengan siswa. o banyak ke banyak (many to many). Kardinalitas ini cukup rumit untuk dijelaskan namun seringkali kita jumpai. Misalnya hubungan siswa dengan mata pelajaran memiliki kardinalitas many-to-many. Siswa berhak mengambil (mempelajari) lebih dari satu matapelajaran dan setiap mata pelajaran boleh diambil (dipelajari) lebih dari satu siswa. 10.3. BASIS DATA RELASIONAL 10.3.1.Model Basis Data Relasional Model basis data relasional diperkenalkan pertama kali oleh E.F. Codd pada tahun 1970. Model data ini didasarkan pada struktur matematis yang mudah dan alami, yaitu relation (tabel). Operasi-operasi manipulasi data semuanya berakar pada logika matematika. Hal ini menjadikan ekspresi-ekspresi pada tabel dapat dianalisis dan dioptimasi (Lewis et al., 2002). Pembentuk utama dalam model data relasional adalan relation (tabel). Relation terdiri dari dua hal penting yaitu schema dan instance. Relation instance tidak lebih dari sebuah tabel dua dimensi dengan baris dan kolom. Baris (row) biasa disebut sebagai tuple, yang memiliki arti sama dengan record dalam suatu file. Tetapi berbeda dengan file record, semua tuple memiliki jumlah kolom yang sama dan tidak ada tuple dalam relation instance yang sama. Kolom dalam relation instance juga dikenal sebagai attribute atau column (Ramakrishnan and Gehrke, 2000; Lewis et al., 2002). Gambar 10.23. menunjukkan bagaimana hubungan tabel/file/relation, row/record/tuple dan column/field/attribute. Gambar ini juga menunjukkan susunan dari hubungan tersebut. 268 Rekayasa Perangkat Lunak Gambar 10.23. Hubungan tabel/file/relation, row/record/tuple dan column/field/attribute. Relation schema terdiri dari nama dari relation, nama dari attribute yang ada pada suatu relation beserta nama domainnya, dan integrity constrains. Nama dari relation haruslah unik dalam suatu basis data, atau tidak boleh ada nama relation yang sama. Nama attribute adalah nama kolom dari relation dan tidak ada nama attribute yang sama pada suatu relation. Nama domain dari suatu attribute berhubungan dengan tipe data yang digunakan oleh attribute tersebut. Integrity constraints adalah batasan pada relational instances pada suatu schema (Ramakrishnan and Gehrke, 2000; Lewis et al., 2002) Rekayasa Perangkat Lunak 269 10.3.2.Struktur Basis Data Relasional Seperti telah dijelaskan di atas sebuah tabel terdiri dari baris dan kolom. x Row/Baris/Tuple Row/Baris/Tuple adalah sekumpulan atribut yang saling berhubungan dalam satu baris (lihat Gambar 10.23). Row ini akan selalu berulang dengan struktur yang sama namun dengan isi data yang berbeda. Sebagai contoh, pada Gambar 10.23, row pertama memiliki struktur yang sama dengan row yang ke 2 dan ke 3. Namun data pada masing-masing row berbeda. Kita dapat mengidentifikasi untuk pembeli dengan id_pembeli = 1 pasti memiliki nama = Cristiano Ronaldo dan untuk id_pembeli = 2 pasti memiliki nama = Ryan Giggs, demikian seterusnya. x Field/Kolom/Attributes Field/Kolom/Attributes menunjukkan struktur dari data dari baris-baris yang berulang. Pada Gambar 10.23, terdapat 4 kolom, yaitu id_pembeli, nama, alamat, dan telepon. Data pada kolom id_pembeli misalnya, akan memiliki struktur yang sama, yaitu dalam bentuk angka dan merupakan urutan id pembeli . Demikian juga pada kolom nama yang hanya berisi nama pembeli saja, tidak bercampur dengan data lain. Sebuah kolom harus memiliki nama kolom dan tipe data untuk data yang berada dalam kolom tersebut (Gambar 10.24). Selain itu, kadang-kadang juga ada pembatas (constraint) dan domain untuk data yang termasuk dalam kolom tersebut. Tipe data akan sangat bergantung pada atribut yang digunakan dan operasi-operasi yang akan dilakukan pada basis data ini. Domain data memiliki banyak kesamaaan pengertian dengan fungsi tipe data yang digunakan. Namun, tipe data lebih merujuk pada kemampuan penyimpanan data yang mungkin bagi suatu atribut secara fisik, tanpa melihat layak tidaknya data tersebut bila dilihat dari pemakaian di dunia nyata. Sementara domain data lebih ditekankan pada batas-batas nilai yang diperbolehkan bagi suatu atribut, dilihat dari kenyataan pemakaiannya. 270 Rekayasa Perangkat Lunak Gambar 10.24. Kolom, constrain dan tipe data (Powell, 2006). Pada Gambar 10.24 terlihat nama-nama kolom pada sebuah tabel lengkap dengan tipe data dan constrainnya. Kolom ISBN misalnya bertipe data integer, artinya kolom ini hanya boleh diisi dengan bilangan integer. Selain itu kolom ini memiliki constrain no null, yang berarti ketika mengisikan data, kolom ini harus selalu terisi tidak boleh dikosongkan. Pada kolom Pages, tipe datanya adalah date, artinya hanya boleh berisi data berbentuk tanggal. Kolom Pages tidak memiliki constrain null, artinya kolom ini boleh diisi atau tidak diisi. Jenis-jenis tipe data tergantung pada DBMS yang digunakan. Sebagai contoh MySQL memberikan jenis-jenis tipe data yang lebih luas dari pada Microsoft Access. Pada MySQL misalnya, kita akan menjumpai tipe data set, enum yang tidak dijumpai dalam Microsoft Access. Pemilihan tipe data yang tepat sangat penting karena mempengaruhi konsistensi data dan kinerja basis data. Contoh domain adalah, apabila kita berhadapan dengan atribut / kolom tentang kelas pada Sekolah Dasar (SD). Kolom kelas ini hanya boleh diisi data angka 1 sampai dengan 6, karena tidak ada kelas 7 atau 4.5 di SD. Artinya domain kolom kelas adalah bilangan integer (bulat dan tidak ada pecahan) antara 1 sampai dengan 6 saja. Contoh lainnya adalah kolom nilai ujian, kolom ini domainnya adalah bilangan asli (real dan boleh pecahan) antara 0 sampai dengan 100. Ada beberapa tipe atribut, yaitu: o Atribut sederhana (Simple Attribute), yaitu atribut atomic yang tidak dapat dipecah lagi. Rekayasa Perangkat Lunak 271 Gambar 10.25. Contoh atribut sederhana o Atribut komposit (Composit Attribute), yaitu atribut yang masih dapat dipecah lagi menjadi sub-sub atribut yang masing-masing memiliki makna. Gambar 10.26. Contoh atribut komposit. 272 o Atribut bernilai tunggal (Single-Valued Attribute), yaitu atribut yang memiliki paling banyak satu nilai untuk setiap baris data. o Atribut bernilai banyak (Multi-Valued Attribute), yaitu atribut yang dapat berisi lebih dari satu nilai tetapi dengan jenis yang sama. Rekayasa Perangkat Lunak Gambar 10.27. Contoh atribut bernilai tunggal dan atribut bernilai banyak. o Atribut turunan (Derived Attribute), yaitu atribut yang nilai-nilainya diperoleh dari hasil pengolahan atau dapat diturunkan dari atribut atau tabel lain yang berhubungan. 10.3.3.Relasi Antar Tabel Keistimewaan utama basis data relasional dibandingkan model basis data lainnya adalah kemudahan dalam membangun hubungan antar tabel dalam bentuk yang masuk akal dapat dimengerti. Relasi antar tabel dapat kita turunkan langsung ataupun tak langsung dari ER-Diagram yang telah dibahas sebelumnya. Entitas yang ada pada ER-Diagram biasanya merupakan kandidat dari suatu tabel pada basis data relasional. Relasi antar tabel biasanya dapat diidentifikasi dari relationship antar entitas pada ER-Diagram. Untuk memperjelas bagaimana basis data relasional menangani hubungan antar tabel kita akan menggunakan tabel-tabel berikut ini. Tabel pertama adalah Pengarang. Tabel ini terdiri dari 3 kolom yaitu id_pengarang, pengarang dan tahun_lahir (Gambar 10.28). Pada tabel ini id_pengarang merupakan primary key. Gambar 10.28. Tabel Pengarang. Rekayasa Perangkat Lunak 273 Tabel kedua adalah Penerbit. Tabel ini mempunyai 6 kolom yaitu, id_penerbit, nama, nama_perusahaan, alamat, kota dan telepon (Gambar 10.29). Primary key pada tabel ini adalah id_penerbit. Gambar 10.29. Tabel Penerbit. Tabel ketiga adalah Buku. Tabel ini mempunyai 6 kolom yaitu, judul, tahun_terbit, ISBN, id_penerbit, deskripsi, dan kelompok (Gambar 10.30). Primary key pada tabel ini adalah ISBN. Ada yang sedikit aneh pada tabel ini, yaitu kolom id_penerbit yang merupakan salah satu kolom pada tabel Penerbit, dimasukkan dalam tabel ini. Sebenarnya ini bukan keanehan atau kesalahan, tetapi memang beginilah salah satu cara basis data relasional menangani hubungan antar tabel. Gambar 10.30 Tabel buku. Dalam dunia nyata, kita akan menjumpai bahwa satu penerbit tidak hanya menghasilkan satu judul buku saja, tetapi ratusan bahkan mungkin jutaan judul buku. Sehingga secara formal hubungan antara penerbit dengan buku dapat dinyatakan sebagai hubungan dengan kardinalitas one-to-many. Jika digambarkan dalam bentuk ER-Diagram akan tampak seperti Gambar 10.31. Satu penerbit dapat menerbitkan banyak judul buku dan satu judul buku hanya diterbitkan oleh satu penerbit. Untuk lebih memperjelas perhatikan Gambar 274 Rekayasa Perangkat Lunak 10.31. Penerbit dengan id_penerbit = 13 (McGraw Hill) menerbitkan 6 buah buku. Sebaliknya buku dengan ISBN = 0-0702063-1-7 (Guide To Oracle) hanya diterbitkan oleh penerbit dengan id_penerbit = 13 (McGraw Hill). Sehingga penempatan kolom id_penerbit pada tabel buku dimaksudkan untuk merepresentasikan hubungan Penerbit dengan Buku. Kolom id_penerbit pada tabel buku biasa disebut sebagai foreign key. Gambar 10.31. ER-Diagram untuk Penerbit dan Buku Gambar 10.32. Hubungan tabel Penerbit dan Buku. Pada tabel-tabel yang telah dibuat di atas kita belum melihat tabel yang menunjukkan seorang pengarang tertentu mengarang buku apa. Untuk Rekayasa Perangkat Lunak 275 membuat tabel yang berisi pengarang dan buku karangannya, kita dapat menggunakan hubungan antara tabel pengarang dengan tabel buku. Namun sebelum itu kita harus melihat bagaimana hubungan antara pengarang dengan buku di dunia nyata. Seorang pengarang mungkin hanya mengarang satu judul buku, tetapi mungkin juga lebih. Sedangkan satu buku, mungkin ditulis hanya oleh satu orang pengarang, tetapi mungkin juga ditulis oleh dua, tiga atau lebih pengarang. Sehingga kita bisa mengatakan kardinalitas hubungan pengarang dengan buku adalah many-to-many. Kita dapat menggambarkan ER-Diagram untuk kasus ini seperti pada gambar 10.33. Gambar 10.33. ER-Diagram untuk Pengarang – Buku. Pada kasus dengan kardinalitas many-to-many kita tidak dapat langsung menyisipkan satu foreign key pada tabel lain. Kita harus membuat tabel baru agar kardinalitas antar tabel yang terlibat dapat diubah menjadi one-to-many. Tabel Pengarang_Buku merupakan tabel yang dibentuk untuk menangani hubungan tabel Buku dengan tabel Pengarang. Tabel ini hanya berisi dua atribut (kolom) yaitu ISBN yang berasal dari tabel Buku dan id_pengarang yang berasal dari tabel Pengarang. Pada Gambar 10.34, terlihat pada tabel Pengarang_Buku ada beberapa buku yang dikarang lebih dari satu pengarang. 276 Rekayasa Perangkat Lunak Gambar 10.34. Hubungan tabel Pengarang dan Buku. Gambar 10.35. Relasi antar tabel. 10.4. RINGKASAN x Basis data (database) merupakan kumpulan dari data yang saling berhubungan satu dengan yang lainnya, tersimpan dalam perangkat keras komputer dan digunakan perangkat lunak untuk memanipulasinya. x Operasi dasar basis data meliputi pembuatan basis data baru, penghapusan basis data, pembuatan tabel baru, penghapusan tabel, Rekayasa Perangkat Lunak 277 pengisian atau penambahan data baru, pengambilan data, pengubahan data, penghapusan data. x Sistem Manajemen Basis Data merupakan perangkat lunak yang bekerja khusus untuk menangani basis data. x Entity-Relationship Diagram merupakan notasi grafis dalam pemodelan data konseptual yang digunakan untuk memodelkan struktur data dan hubungan antar data. Elemen dari ERD adalah entitas, atribut, relationship dan kardinalitas. x Pembentuk utama dalam model data relasional adalan relation (tabel). Relation instance adalah sebuah tabel dua dimensi dengan baris (row/record/tuple) dan kolom (column/field/attribute). x Pada basis data relasional, identifikasi yang tepat pada hubungan antar atribut di dalam satu tabel dan hubungan antar tabel merupakan kunci membuat basis data yang baik. 10.5. SOAL-SOAL LATIHAN 1. Berkunjunglah ke perpustakaan sekolah, kemudian buatlah pengamatan singkat. Buatlah catatan untuk menentukan siapa dan apa yang terlibat dalam kegiatan perpustakaan sekolah. Cermatilah mana yang bisa digolongkan sebagai entitas, atribut. Dan bagaimana hubungan antar entitas. 2. Dari hasil kegiatan no. 1 kemudian buatlah tabel-tabel yang menunjukkan entitas dan hubungannya. Tentukan pula atribut dari masing-masing tabel. 3. Cermati pula tipe-tipe atribut yang telah kalian tentukan. 278 Rekayasa Perangkat Lunak Anonymous. 2004. Guide to the Software Engineering Body of Knowledge (SWEBOK). The Institute of Electrical and Electronics Engineers, Inc. Balter, A. 2006. Sams Teach Yourself Microsoft® SQL Server™ 2005 Express in 24 Hours. Sams. Bass, L., P. Clements, and R. Kazman. 2003. Software Architecture in Practice. 2nd Edition. Addison-Wesley. Cormen, T.H. 2001. Introduction to Algorithm: Second Edition. The MIT Press. Deek, FP., J.A.M. McHugh, and O.M. Eljabiri. 2005. Strategic software engineering : An Interdisciplinary Approach. Auerbach Publications. den Haan, P., L. Lavandowska, S.N. Panduranga, and K. Perrumal. Beginning JSP 2: From Novice to Professional. Apress. 2004. Dobson, R. 1999. Programming Microsoft Access 2000: The Developer’s Guide to Harnessing the Power of Access. Microsoft Press. Felleisen, M, R.B. Findler, M. Flatt, and S. Krishnamurthi. 2001. How to Design Programs; An Introduction to Computing and Programming. The MIT Press. Kak, A.C. 2003. Programming With Objects: A Comparative Presentation of Object Oriented Programming with C++ and Java. John Wiley & Sons, Inc. Kaisler, S.H. 2005. Software Paradigm. John Wiley & Sons, Inc. Kennedy, B. and C. Musciano. 2006. HTML & XHTML: The Definitive Guide, 6th Edition. O'Reilly. Lafore, R. 1998. Data Structures & Algorithm in Java. Waite Group Press. Laurie, B and P. Laurie. 2001. Apache: The Definition Guide. O’Reilly and Associates, Inc. 2nd Edition. Leffingwell, D. and D. Widrig. 2003. Managing Software Requirements: A Use Case Approach. 2nd Edition. Addison-Wesley. Lischner, R. 2000. Delphi in a Nutshell. O’Reilly and Associates, Inc. Rekayasa Perangkat Lunak A1 Luckey, T. and J. Phillips. 2006. Software Project Management for Dummies. Wiley Publishing, Inc. McConnel, S. 2003. Professional Software Development: Shorter Schedules, Higher Quality Products, More Successful Projects, Enhanced Careers. Addison-Wesley. Meyer, B. 2000. Object Oriented Software Construction. 2nd Edition. ISE, Inc. Musciano, C. and B. Kennedy. 2002. HTML and XHTML: The Definition Guide. 4th Edition. O’Reilly and Associates, Inc. Navarro, A. 2001. Effective Web Design. 2nd Edition. SYBEX, Inc. Powell, G. 2006. Beginning Database Design. Wiley Publishing, Inc. Riordan, R.M. 2005. Designing Effective Database Systems. Addison Wesley Professional. Robbins, J. N. 2006. Web Design in a Nutshell, 3rd Edition. O'Reilly. Suehring, S. 2002. MySQL Bible. Wiley Publishing, Inc. Taylor, D.A. 1998. Object Technology: A Manager’s Guide. Addison-Wesley. Van Roy, P and S. Haridi. 2004. Concepts, Techniques, and Models of Computer Programming. The MIT Press. A2 Abstraction Merupakan prinsip penyederhanaan dari sesuatu yang kompleks dengan cara memodelkan kelas sesuai dengan masalahnya Algoritma Urutan langkah-langkah logis penyelesaian masalah yang disusun secara sistematis Array Struktur data yang menyimpan sekumpulan elemen yang bertipe sama Atribut Karakteristik atau ciri yang membedakan antara entitas satu dengan entitas yang lainnya Authentication Proses memeriksa keabsahan seseorang sebagai user (pengguna) pada suatu system (misalnya pada DBMS) Basic Input/Output System (BIOS) Kode-kode program yang pertama kali dijalankan ketika komputer dinyalakan (booting) Basis data (database) Kumpulan dari data yang saling berhubungan satu dengan yang lainnya, tersimpan dalam perangkat keras komputer dan digunakan perangkat lunak untuk memanipulasinya Command Line Interface (CLI) Antar muka pengguna dengan model perintah-perintah teks Compiler Penerjemah bahasa pemrograman tingkat tinggi ke bahasa mesin dengan cara sekaligus seluruh kode program. Prosesnya disebut kompilasi. Component Object Model (COM) Infrastruktur yang disediakan oleh Visual Basic untuk mengakses obyek-obyek atau kontrol-kontrol lain sepanjang punya antar muka yang dapat diakses oleh Visual Basic. Rekayasa Perangkat Lunak B1 Constraint Batasan-batasan dari masalah Control Aktivitas monitoring dan evaluasi terhadap feedback untuk menentukan apakah system telah bekerja dengan baik atau tidak Counter Variable pencacah yang digunakan dalam struktur algoritma pengulangan Database Management System (DBMS) Perangkat Lunak yang khusus / spesifik ditujukan untuk pengelolaan basis data Disk Operating System (DOS) Salah satu sistem operasi lama berbasis CLI Elektronika Ilmu yang mempelajari alat listrik arus lemah yang dioperasikan dengan cara mengontrol aliran elektron atau partikel bermuatan listrik dalam suatu alat Entitas Individu yang mewakili sesuatu yang nyata (eksistensinya) dan dapat dibedakan dari sesuatu yang lain Extensible Hypertext Markup Language (XHTML) HTML versi terakhir (4.01) yang ditulis ulang dengan dengan aturan-aturan yang lebih ketat mengacu pada XML Extensible Markup Language (XML) Sekumpulan aturan untuk menyusun bahasa markup Feedback Data tentang kinerja sistem Flowchart Skema/bagan (chart) yang menunjukkan aliran (flow) di dalam suatu program secara logika Gejala Signal atau tanda terjadinya suatu masalah Gerbang logika blok-blok penyusun dari perangkat keras elektronik Graphical User Interface (GUI) Antar muka pengguna dengan model grafis Identifier B2 Lampiran Nama dari suatu variable atau konstanta Ilmu komputer Suatu studi sistematis pada proses-proses algoritma yang menjelaskan dan mentransfor-masikan informasi Inheritance atau pewarisan Prinsip pewarisan sifat dari orang tua ke anak atau turunannya yang diterapkan pada kelas Inisialisasi Instruksi yang dilakukan pertama kali pada suatu variabel atau ekpresi pemrograman Input Elemen-elemen yang masuk ke dalam system Integrated Developement Environment (IDE) Lingkungan pengembangan aplikasi terintegrasi. Perangkat lunak untuk membantu mempermudah pembuatan aplikasi komputer Interpreter Penerjemah bahasa pemrograman tingkat tinggi ke bahasa mesin dengan cara satu per satu baris dibaca dan langsung diterjemahkan Kardinalitas Jumlah maksimum entitas pada suatu himpunan entitas yang dapat berelasi dengan entitas pada himpunan entitas yang lain Konstanta Variabel yang nilai datanya bersifat tetap dan tidak bisa diubah. Loop Proses pengulangan suatu perintah Masalah (problem) Perbedaan antara situasi aktual dan situasi yang diharapkan atau perbedaan antara kondisi sekarang dengan target atau tujuan yang diinginkan Model Penyederhanaan dari suatu system atau Tiruan dari suatu sistem dengan sedikit atau banyak penyederhanaan Multi-tasking Rekayasa Perangkat Lunak B3 Kemampuan sistem operasi untuk menjalankan beberapa tugas / aplikasi secara bersamaan Multi-user Kemampuan system operasi untuk dijalankan oleh pengguna yang berbeda pada waktu bersamaan Output Perpindahan elemen-elemen yang dihasilkan dari proses perubahan ke tujuan yang diinginkan Pemecahan masalah Sebuah proses dimana suatu situasi dianalisa kemudian solusi-solusi dibuat bila ditemukan ada masalah dengan cara pendefinisian, pengurangan atau penghilangan, atau pencegahan masalah Pemrograman Berorientasi Obyek (Object Oriented Programming – OOP) Paradigma pemrograman yang menggunakan obyek dan interaksinya untuk merancang aplikasi dan program komputer Pemrograman web Usaha untuk membuat pemrograman web (script) halaman web dengan menggunakan bahasa Perangkat lunak Seluruh instruksi yang digunakan untuk memproses informasi Permissions Proses untuk menentukan apa yang bisa dilakukan seorang pengguna pada suatu sistem Pointer Variabel yang menyimpan alamat pada memori komputer Polymorphism Kemampuan dari suatu obyek untuk mempunyai lebih dari satu bentuk Programmer Seseorang yang bekerja membuat program komputer Prosedur • Instruksi yang dibutuhkan oleh pengguna dalam memproses informasi • Sekumpulan perintah yang merupakan bagian dari program yang lebih besar yang berfungsi mengerjakan suatu tugas tertentu Proses Perubahan atau transformasi input menjadi output B4 Lampiran Prototyping Salah satu pendekatan dalam pengembangan perangkat lunak yang secara langsung mendemonstrasikan bagaimana sebuah perangkat lunak atau komponen-komponen perangkat lunak akan bekerja dalam lingkungannya sebelum tahapan konstruksi aktual dilakukan Pseudocode Cara penulisan algoritma dengan menggunakan kode-kode yang mirip dengan bahasa pemrograman Query Permintaan atau pencarian pada data-data tertentu pada suatu basis data Record Baris data dari suatu tabel Rekayasa Perangkat Lunak suatu disiplin ilmu yang membahas semua aspek produksi perangkat lunak, mulai dari tahap awal yaitu analisa kebutuhan pengguna, menentukan spesifikasi dari kebutuhan pengguna, disain, pengkodean, pengujian sampai pemeliharaan sistem setelah digunakan Relationship atau relasi Hubungan yang terjadi antara sejumlah entitas Sistem Kumpulan dari elemen-elemen yang saling berinteraksi untuk mencapai tujuan tertentu Sistem basis data Kumpulan elemen-elemen seperti basis data, perangkat lunak, perangkat keras, dan manusia yang saling berinteraksi untuk mencapai tujuan yaitu pengorganisasian data. Software Lihat Perangkat Lunak Software Engineering Lihat Rekayasa Perangkat Lunak Solusi Bagian akhir atau output dari proses pemecahan masalah. Stored procedure Rekayasa Perangkat Lunak B5 Potongan kode program yang dapat menerima parameter input dan menghasilkan satu atau lebih parameter output dan digunakan untuk operasioperasi basis data Structured Query Language (SQL) Bahasa query terstruktur untuk mengelola basis data Strategi pemecahan masalah Metode atau pendekatan yang digunakan seseorang ketika menghadapi masalah Struktur algoritma Cara atau urutan untuk membuat suatu algoritma Tipe data Jenis data yang dapat diolah oleh komputer untuk memenuhi kebutuhan dalam pemrograman komputer Trigger Tipe khusus dari stored procedure yang akan dieksekusi ketika suatu kejadian muncul Variabel Tempat dimana kita dapat mengisi atau mengosongkan nilainya dan memanggil kembali apabila dibutuhkan pada suatu program View Tabel virtual yang isinya berdasarkan pada query yang dilakukan pada basis data. Web browser Perangkat lunak yang berfungsi menerjemahkan kode-kode HTML menjadi tampilan yang kita kehendaki Web dinamis Halaman-halaman web yang isi dan informasinya berubah-ubah sesuai dengan permintaan pengguna Web server Perangkat lunak yang bertindak melayani permintaan-permintaan client terhadap halaman-halaman web tertentu Web statis Halaman-halaman web yang isi dan informasinya tidak berubah-ubah B6 Lampiran Berikut ini daftar alamat situs-situs internet yang penting dan digunakan sebagai rujukan dalam buku ini. Alamat Keterangan http://www.apache.org Situs resmi web server Apache. Situs ini menyediakan kode sumber Apache dan file-file binary Apache yang siap diinstall di berbagai platform sistem operasi. Selain itu juga menyediakan dokumentasi Apache yang lengkap. http://www.borland.com Situs resmi Borland. Borland merupakan perusahaan perangkat lunak yang memproduksi Borland Delphi, Borland JBuilder, Turbo Pascal, Turbo Delphi, Borland C++ dan lain-lain. http://www.debian.org Situs resmi distribusi linux Debian. http://www.eclipse.org Situs resmi proyek eclipse, perangkat pengembang terpadu yang mendukung banyak bahasa pemrograman. http://www.google.com Situs resmi search engine Google. http://www.ilmukomputer.com Situs berbahasa Indonesia yang menyediakan dokumen-dokumen untuk belajar berbagai sub bidang dalam ilmu computer. http://www.javasoft.com Situs resmi yang diluncurkan Sun Microsystem dan berisi dokumentasi dan informasi online tentang bahasa pemrograman Java. http://www.kambing.vlsm.org Situs dengan server local di Indonesia. Situs ini menyediakan file-file iso dari berbagai jenis distribusi linux dan dapat didownload secara bebas. Selain itu situs ini juga sebagai mirror dari berbagai distribusi linux dan aplikasi yang berjalan di linux. http://www.linuxdoc.org Situs yang berisi dokumentasi bebas tentang linux. Sumber informasi online yang sangat bagus untuk mempelajari linux Rekayasa Perangkat Lunak B7 http://www.microsoft.com Situs resmi Microsoft. Microsoft merupakan perusahaan perangkat lunak yang memproduksi system operasi keluarga Windows, IDE Microsoft Visual Studio, Microsoft Office, Microsoft SQL Server, dan lain-lain. http://www.mysql.com Situs resmi MySQL Database Software. Situs ini menyediakan file-file instalasi MySQL untuk berbagai platform sistem operasi. Selain itu juga menyediakan dokumentasi MySQL yang lengkap. http://www.netbeans.org Situs resmi IDE Netbeans, perangkat lunak pengembang aplikasi Java http://www.php.net Situs resmi bahasa pemrograman dan interpreter PHP. Situs ini menyediakan kode sumber dan file-file instalasi PHP untuk berbagai platform sistem operasi. Selain itu juga menyediakan dokumentasi PHP yang lengkap. http://www.w3.org Situs resmi The World Wide Web Consortium (W3C). W3C adalah konsorsium yang menentapkan standar dalam teknologi internet, terutama tentang HTML, XML, CSS, XHTML dan teknologi lain. Dokumentasi tentang teknologi tersebut dapat dijumpai di situs ini. B8 Lampiran IsNumeric(ekspresi) Fungsi ini digunakan untuk menguji apakah suatu ekspresi menghasilkan nilai numeric atau bukan. Nilai yang dikembalikan adalah Boolean. IsEmpty(ekspresi) Fungsi untuk memeriksa apakah suatu ekspresi telah berisi nilai atau tidak. Nilai yang dikembalikan adalah Boolean.. IsNull(ekspresi) Fungsi untuk memeriksa apakah suatu ekspresi mengandung data yang tidak valid, biasanya digunakan untuk memeriksa isi field recordset. IsArray(varname) Fungsi untuk memeriksa apakah suatu variabel adalah suatu array. IsDate(ekspresi) Fungsi untuk memeriksa apakah suatu ekspresi dapat dikonversi ke date. IsError(ekspresi) Fungsi untuk memeriksa apakah suatu ekspresi adalah nilai error IsObject(ekspresi) Fungsi untuk memeriksa apakah suatu ekspresi mengacu pada suatu OLE Automation object. IsMissing(argname) Fungsi untuk memeriksa apakah suatu argumen optional pada procedure ada dilewatkan atau tidak CBool(ekspresi) Konversi suatu ekspresi ke Boolean CByte(ekspresi) Konversi ekspresi ke Byte CCur(ekspresi) Konversi suatu ekspresi ke Currency CDate(date) Konversi suatu ekspresi ke date CDbl(ekspresi) Konversi suatu ekspresi ke Double CInt(ekspresi) Konversi suatu ekspresi ke Integer CLng(ekspresi) Rekayasa Perangkat Lunak B9 Konversi suatu ekspresi ke Long CSng(ekspresi) Konversi suatu ekspresi ke single CStr(ekspresi) Konversi suatu ekspresi ke string CVar(ekspresi) Konversi suatu ekspresi ke Variant Asc(string) Fungsi untuk menampilkan kode character dari huruf pertama di suatu string. Chr(charcode) Fungsi untuk menampilkan karakter dari suatu kode karakter Format(ekspresi[, format[, hariPertamaDariMinggu[, mingguPertamaDariTahun]]]) Memformat suatu ekspresi berdasarkan ekspresi format Hex(number) dan Oct(number) Menampilkan string yang mewakili Octal atau Hexa dari suatu bilangan Str(number) Menampilkan string yang mewakili suatu angka. Val(string) Menampilkan angka yang terkandung dalam suatu string. Now Mengembalikan suatu Variant (Date) yang menunjukkan tanggal dan waktu berdasarkan sistem komputer. Time Mengembalikan waktu sistem sekarang Timer Mengembalikan suatu bilangan yang menunjukan jumlah detik sejak tengah malam Date Mengembalikan tanggal sistem sekarang Time = Time dan Date = Date Mengatur waktu atau tanggal sistem Untuk sistem yang menjalankan dibutuhkan harus berupa tanggal Untuk sistem yang menjalankan dibutuhkan harus berupa tanggal 2079. Microsoft Windows 95, dari 1 Jan 1998 sampai Microsoft Windows NT, dari 1 Jan 1980 sampai tanggal yang 31 Des 2099. tanggal yang 31 Desember Hour(time), Minute(time) dan Second(time) Mengembalikan suatu Variant (Integer) berupa bilangan 0 s/d 23 untuk jam, 0 s/d 59 untuk menit, dan 0 s/d 59 untuk detik. B10 Lampiran Day(date), Month(date), dan Year(date) Mengembalikan suatu Variant (Integer) berupa bilangan 1 s/d 31 untuk bulan, 1 s/d 12 untuk bulan, dan tahun. Rekayasa Perangkat Lunak B11 B12 Lampiran Judul Gambar Halaman 1.1. 1.2. 1.3. 1.4. 1.5. 1.6. 1.7. 1.8. 1.9. 1.10. 1.11. 1.12. Tampilan desktop Microsoft Windows Tujuan RPL. Ruang lingkup RPL (Abran et.al., 2004). Klasifikasi disiplin ilmu komputer menurut ACM (1998). Klasifikasi disiplin ilmu komputer menurut Denning (2000). Klasifikasi disiplin ilmu komputer menurut Wikipedia (2007). Keterkaitan RPL dengan bidang ilmu lain. Perkembangan RPL. Profesi dokter. Gejala dan masalah. Tipe-tipe masalah (Deek et al, 2005). Proses pemecahan masalah (diadopsi dari Deek et al, 2005) 1 3 3 5 6 7 8 9 10 11 11 13 2.1. 2.2. 2.3. 2.4. 2.5. 2.6. 2.7. 2.8. 2.9. 2.10 Bekerja dengan komputer. System Development Life Cycle (SDLC). The Waterfall Model Klasifikasi prototyping model (Harris, 2003) Tahapan-tahapan prototyping model (Harris, 2003) RUP Life Cycle (Ambler, 2005). Tahapan dan aktifitas dalam analisis. Notasi pada DFD. Tahapan pembuatan DFD. Context diagram sistem pemesanan makanan (Hoffer et al., 2002). DFD Level 0. Tipe-tipe perawatan. 17 18 20 21 22 23 26 27 28 28 Rangkaian dan perangkat elektronik.s Resistor Kapasitor Induktor. Tabel kebenaran dan representasinya dalam gerbang logika. Bentuk turunan tabel kebenaran dan representasinya dalam gerbang logika. Contoh rangkaian digital dan representasinya pada hardware. Sistem Komputer Komponen dasar komputer Perangkat keras komputer Display atau monitor Motherboard sebuah komputer 35 37 38 38 39 40 2.11. 2.12. 3.1. 3.2. 3.3. 3.4. 3.5. 3.6. 3.7. 3.8. 3.9. 3.10 3.11 3.12. Rekayasa Perangkat Lunak C1 29 32 41 42 42 44 45 45 3.13. 3.14. 3.15. 3.16. 3,17. 3.18. 3.19. 3.20. 3.21. 3.22. 3.23. 3.24. 3.25. 4.1. 4.2. 4.3. 4.4 4.5 4.6. 4.7. 4.8. 4.9. 4.10. 4.11. 4.12. 4.13. 4.14. 4.15. 4.16. 4.17. 4.18. 4.19. 4.20. 4.21. 4.22. 4.23. 4.24. 4.25. 4.26. 4.27. 4.28. 4.29. 4.30. Central Processing Unit (CPU) Berbagai jenis main memory Pemasangan expansion card Power Supply Unit CD-RW Drive, salah satu contoh Optical Disc Drive Hard Disk Skema umum sebuah keyboard Berbagai jenis mouse Tampilan desktop sistem operasi Windows XP Application software Microsoft Word (Software pengolah kota). Application software Winrar (Software kompresi dan ekstraksi file). Application software PowerSim (Software untuk simulasi sistem) Application software Hysis (Software untuk perancangan pabrik). 46 46 47 47 48 49 49 50 51 52 Menjalankan sistem operasi berbasis teks. Fungsi-fungsi sistem operasi Manajemen memori pada sistem operasi Microsoft Windows Windows Explorer sebagai sarana pengelolaan file Manajemen proses pada sistem operasi Microsoft Windows Manajemen I / O pada sistem operasi Microsoft Windows. Tampilan BIOS utility Contoh penggunaan DOS Unix dan sistem operasi turunannya Manajemen memori dan penjadwalan proses pada Unix X windows system di UNIX Windows versi 3.11 Windows Vista Mac OS versi awal Mac OS X Linux dengan desktop KDE Testing media instalasi Proses penentuan target instalasi Proses copy file pada Fedora Proses awal booting Proses booting pada Linux Fedora Terminal sedang menjalankan mode CLI Perintah-perintah pada direktori sbin Perintah-perintah pada direktori /usr/sbin. Perintah-perintah pada direktori bin. Perintah-perintah pada direktori /usr/bin Contoh penggunaan perintah ls Contoh penggunaan perintah cd Contoh penggunaan perintah find Contoh penggunaan perintah cat dan more 55 57 58 59 60 61 62 63 64 65 66 67 67 68 69 70 72 72 73 74 75 76 77 77 78 78 79 79 80 80 C2 Rekayasa Perangkat Lunak 52 53 53 4.31. 4.32. 4.33. 4.34. 4.35. 4.36. 4.37. 4.38. 4.39. 4.40. 4.41. 4.42. 4.43. 4.44. 4.45. 4.46. 4.47. 4.48. 4.49. 4.50 4.51 5.1. 5.2. 5.3. 5.4 5.5. 5.6. 5.7. 5.9. 5.10. 5.11. 5.12. 5.13. 5.14. 5.15. 5.16. 5.17. 5.18. 5.19. 5.20. 5.21. 5.22. 5.23. Contoh penggunaan perintah cp Contoh penggunaan perintah mv untuk memindahkan file. Contoh penggunaan perintah mv untuk mengganti nama file. Contoh penggunaan perintah rm untuk menghapus file atau direktori Contoh penggunaan perintah mkdir Attribute file / folder pada Microsoft WIndows Attribute file / direktori pada keluarga Unix Eksekusi perintah ps Penggunaan perintah df. Contoh hasil eksekusi perintah man untuk melihat manual suatu perintah. Membuka konteks menu dengan klik kanan. Drag and drop Network Interface Card Membuka system properties Device manager Output perintah lspci untuk memeriksa network adapter.. Memeriksa protocol TCP/IP Kondisi koneksi jaringan Mengatur file sharing Menjelajah komputer yang ada di jaringan Printer sharing Perangko bergambar Muhammad ibn Mūsā al-Khwārizmī Pengelompokkan tipe data Simbol-simbol yang digunakan dalam flowchart Program flowchart Mobil sedang berjalan pada jalur lurus. Flowchart menghitung volume balok dan luas lingkaran. Flowchart untuk konversi suhu Flowchart penyelesaian masalah nonton film Flowchart penyelesaian untuk perhitungan dua buah bilangan Flowchart penyelesaian untuk masalah fotokopi Flowchart penyelesaian untuk kelulusan siswa. Lomba balap mobil di sirkuit Struktur algoritma pengulangan dengan For. Flowchart menulis pernyataan 100 kali Flowchart mencetak anggota himpunan Flowchart mencetak bilangan tertentu Flowchart dengan pengulangan bersarang Flowchart umum While. Flowchart pengulangan dengan while untuk mencetak nilai tertentu Lemari dengan banyak kotak laci di dalamnya Flowchart untuk pencarian bilangan Flowchart untuk pengurutan bilangan Rekayasa Perangkat Lunak C3 81 81 82 82 83 83 84 85 86 86 87 88 88 89 90 90 91 92 93 94 94 97 100 108 109 109 111 111 112 113 115 116 117 118 119 120 121 122 123 124 125 128 130 6.1. 6.2. 6.3. 6.4. 6.5. 6.6. 6.7. Notasi matrik Perbedaan array satu dimensi dan dua dimensi Matrik 4 x 3 Algoritma untuk membuat matrik 4 x 3 Algoritma penjumlahan dua buah matrik Skema penggunaan prosedur Penyelesaian contoh 6.3 135 136 137 138 139 140 141 7.1. 7.2. 7.3. 7.4. 7.5. 7.6. 7.7. 7.8. Aplikasi yang dibangun dengan Visual Basic Tampilan awal Visual Basic Tampilan awal untuk pilihan Standard.EXE IDE Visual Basic Toolbox VB 6 Obyek, Property, Method dan Event Berbagai cara akse basis data dari Visual Basic Jendela Reference 145 146 147 148 149 151 167 170 8.1. 8.2. 8.3. 8.4. 8.5. 8.6. 8.7. 8.8. 8.9. 8.10. 8.11. 8.12. 8.13. 8.14. 8.15. 8.16. 8.17. 8.18 Logo Java Kelas, atribut dan method Contoh abstraction Pewarisan Netbeans IDE Nama file dan lokasi penyimpanan Cara eksekusi program dalam Java Peringatan terjadinya kesalahan Output dari try-catch Output program dengan throw Output kode program try-catch-finally Hasil eksekusi multi-thread Hasil eksekusi terhadap class DataSiswa Eksekusi pada class yang mempunyai method Hasil eksekusi program kelas Bangun dan Box. Hasil eksekusi overriding pada method hitungLuas() Hasil eksekusi overriding dan pernyataan super. Kompilasi pada tiga file anggota paket 173 174 175 176 177 179 179 191 192 193 194 198 200 202 208 210 210 215 9.1. 9.2. 9.3. 9.4. 9.5. 9.6. 9.7. 9.8. 9.9. 9.10. Pesawat Luar Angkasa Proses kompilasi pada C++ MingGW Developer Studio Hasil eksekusi deklarasi pointer Hasil eksekusi pointer NULL Output hasil eksekusi program array sederhana Hasil eksekusi deklarasi dan inisialisasi array Hasil eksekusi array multidimensi Hasil eksekusi fungsi virtual dan overriding. Abstraksi kasus persediaan barang di toko buku 221 223 223 239 240 241 242 244 251 254 10.1. Fasilitas contact list pada pesawat telepon seluler. 259 C4 Rekayasa Perangkat Lunak 10.2. 10.3. 10.4. 10.5. 10.6. 10.7. 10.8. 10.9. 10.10. 10.11. 10.12. 10.13. 10.14. 10.15. 10.16. 10.17. 10.18. 10.19. 10.20. 10.21. 10.22. 10.23. 261 262 263 264 264 265 265 266 266 267 267 268 268 269 269 270 271 271 273 274 274 276 10.24. 10.25. 10.26. 10.27. 10.28. 10.29. 10.30. 10.31. 10.32. 10.33. 10.34. 10.35. Lemari arsip dan basis data Tingkatan dalam abstaksi data (Lewis et al., 2002) Operasi-operasi dasar pada basis data Struktur umum DBMS Logo Microsoft Access Tampilan Microsoft Access Logo MySQL Tampilan awal phpMyAdmin Logo Microsoft SQL Server GUI pada Microsoft SQL Server Logo PostgreSQL Logo Oracle Notasi entitas pada ER-Diagram Penggunaan notasi atribut pada ER-Diagram Penggunaan notasi relationship pada ER-Diagram Entitas siswa dan atributnya Entitas guru dan atributnya Entitas mobil dan atributnya Relationship Hubungan one-to-one suami dan istri Hubungan one-to-many kelas dengan siswa Hubungan table/file/relation, row/record/tuple dan column/field/attribute Kolom, constraint dan tipe data (Powell, 2006). Contoh atribut sederhana Contoh atribut komposit Contoh atribut bernilai tunggal dan atribut bernilai banyak. Tabel Pengarang Tabel Penerbit Tabel buku ER-Diagram untuk Penerbit dan Buku Hubungan table Penerbit dan Buku ER-Diagram untuk Pengarang – Buku Hubungan table Pengaran dan Buku Relasi antar table 11.1. 11.2. 11.3. 11.4. 11.5. 11.6. 11.7. 11.8. 11.9. 11.10. 11.11. 11.12. Microsoft Access 2007 Tampilan awal Microsoft Access Penentuan nama dan lokasi basis data Bagian-bagian sebuah basis data pada Microsoft Access Toolbar pada menu Create Toolbar pada menu External Data Toolbar pada menu Database Tool ER Diagram untuk kasus Basis Data Penjualan Buku Tahap awal pembuatan table Pendefinisian field, tipe data, constraint dan domain Toolbar Microsoft Access Struktur table pembeli 288 286 287 287 288 289 289 270 292 293 293 294 Rekayasa Perangkat Lunak C5 277 278 278 279 279 280 280 281 281 282 283 283 11.13. 11.14. 11.15. 11.16. 11.17. 11.18. 11.19. 11.20. 11.21. 11.22. 11.23. 11.24. 11.25. 11.26. 11.27. 11.28. 11.29. 11.30. 11.31. 11.32. 11.33. 11.34. 11.35. 11.36. 11.37. 11.38. 11.39. 11.40. 11.41. 11.42. 11.43. 11.44. 11.45. 11.46. 11.47. 11.48. 11.49. 11.50. 11.51. 11.52. 11.53. 11.54. 11.55. 11.56. 11.57. 11.58. 11.59. 11.60. Struktur table buku Struktur table pesanan Struktur table item_pesanan Hasil pengisian data pada table pembeli Hasil pengisian data pada table buku Hasil pengisian data pada table pesanan Hasil pengisian data pada table item_pesanan Jendela Relationships Jendela Show Table Tabel-tabel yang akan direlasikan Jendela untuk edit relationships Relasi untuk keseluruhan table Jendela query pada mode design view Prosedur dan hasil query table buku Query nama pengarang dan bukunya Query judul buku dan harga dengan urutan Query dengan criteria tertentu Query dengan menggunakan operator and Query dengan menggunakan operator or Pemilihan table untuk query dua table. Query dua tabel Query tiga table. Query empat table Jenis-jenis form Membuka jendela Form Wizard Pemilihan table yang akan dibuat formnya Pemilihan field untuk form Jendela untuk memilih model tampilan form Jendela untuk memilih style form Jendela untuk memberi nama form Form Pembeli Form Buku Jendela Form Pembeli pada mode Design View Bagian-bagian suatu form Perubahan pada Label fields pada Form Pembeli Modifikasi tampilan form Mendefinisikan aksi untuk suatu Command Button Mendefinisikan teks pada Command Button Mendefinisikan nama Command Button Mendefinisikan nama Command Button Hasil modifikasi Form Pembelian Jendela query untuk sumber report Pemilihan query sebagai sumber data laporan. Pemilihan fields yang terlibat Jendela untuk menentukan dasar tampilan report Jendela untuk menentukan grouping data Jendela untuk menentukan urutan data Jendela untuk mengatur tampilan ringkasan C6 Rekayasa Perangkat Lunak 294 294 294 295 295 295 296 296 296 297 297 298 299 300 301 302 302 303 304 305 306 307 308 309 309 310 310 311 311 312 312 313 313 314 315 315 316 316 317 318 319 320 320 321 322 322 323 323 11.61. 11.62. 11.63. 11.64. 11.65. 11.66. Jendela untuk mengatur lay-out dan orientation Jendela untuk mengatur style laporan Hasil pembuatan laporan menggunakan Wizard Laporan dalam mode Design View Design laporan setelah dilakukan perbaikan Print Preview laporan setelah perbaikan 324 324 325 325 326 327 12.1. 12.2. 12.3. 12.4. 12.5. 12.6. 12.7. 12.8. 12.9. 12.10. 12.11. 12.12. 12.13. 12.14. 12.15. 12.16. 12.17. 12.18. 12.19. 12.20. 12.21. 12.22. 12.23. 12.24. Perangkat komputer server Jendela Administrative Tool Jendela Services Tampilan autentikasi SQL Server Management Studio Tampilan awal SQL Server Management Studio. Obyek Databases Isi dari basis data pada SQL Server Mendefinisikan basis data baru Pembuatan tabel Pengisian tabel. Jendela untuk menambah tabel yang berhubungan Relasi antar tabel Jendela untuk menentukan tabel yang akan dibuat View. Jendela untuk membuat View Hasil eksekusi View Hasil eksekusi View contoh 12.1 Hasil eksekusi View contoh 12.2 Hasil eksekusi View contoh 12.3 Membuka jendela query Isi tabel Bidang Isi tabel Bidang setelah INSERT data Halaman security pada jendela Server Properties Jendela untuk membuat user baru Hak akses basis data oleh user 329 332 332 333 334 335 335 336 337 339 339 340 341 342 343 344 345 346 349 350 361 362 363 13.1. 13.2. 13.3. 13.4. 13.5. 13.6. 13.7. 13.8. 13.9. 13.10. 13.11. 13.12. 13.13. 13.14. 13.15. 13.16. Halaman web Menjalanka service Apache (httpd) pada Linux Memeriksa dan menginstal IIS Microsoft Internet Explorer Safari. Opera. Contoh Struktur direktori situs web File index.html dan lokasi penyimpanannya Hasil pengujian file index.htm Teks editor Notepad Macromedia Dreamweaver Quanta pada system operasi Linux Bluefish pada system operasi Linux Struktur umum dokumen HTML Header dokumen HTML tanpa tag title Header dokumen HTML dengan tag title 365 369 370 371 372 372 373 374 375 376 376 377 377 379 379 380 Rekayasa Perangkat Lunak C7 13.17. 13.18. 13.19. 13.20. 13.21. 13.22. 13.23. 13.24. 13.25. 13.26. 13.27. 13.28. 13.29. 13.30. 13.31. 13.32. 13.33. 13.34. 13.35. 13.36. 13.37. Dokumen HTML dengan body content sederhana Dokumen HTML dengan body content yang lebih kompleks Penggunaan heading Penggunaan paragraph Tag
dan

. Penggunaan Ordered List Penggunaan Unordered List Penggunaan Direktori List Penggunaan Menu List Penggunaan Definition lis List Penggunaan tag Font Penggunaan garis Penggunaan tag image Penggunaan attribute-attribute tag IMG Table sederhana Tabel dengan format yang lebih kompleks Cellpadding, cellspacing dan border Rowspan. Colspan. Tabel dengan sel berisi gambar Penggunaan tag anchor 380 381 381 382 382 383 384 384 385 385 386 387 387 388 389 389 390 391 391 392 392 14.1. 14.2. 14.3. 14.4. 14.5. 14.6. 14.7. 14.8. 14.9. 14.10. 14.11. 14.12. 14.13. 14.14. 14.15. 14.16. 14.17. 14.18. 14.19. 14.20. 14.21. 14.22. 14.23. Halaman pencarian Google Pertukaran data antara client dan server Jendela Services Opera sedang memanggil alamat server Daftar perangkat lunak yang terinstal pada Windows Lokasi direktori yang bisa dibaca web server Pengujian halaman web dinamis Mekanisme kerja aplikasi web dengan JSP NetBeans 6.1 dengan Apache Tomcat terintegrasi Admin Console Java Application Server Penentuan lokasi penyimpanan file Penetuan tipe project Penentuan nama dan lokasi project Tipe dan pengaturan server Lingkungan kerja NetBeans Struktur direktori aplikasi JSP Hasil eksekusi halaman web JSP Hasil eksekusi penggunaan tag deklarasi Hasil eksekusi tag ekspresi Hasil eksekusi halaman login.html Hasil eksekusi jika nama dan password benar Penyerangan dengan DOS Membatasi akses untuk IP address tertentu 395 398 401 402 403 404 405 406 408 408 409 410 410 411 411 412 413 415 416 419 419 421 422 C8 Rekayasa Perangkat Lunak No. Judul Tabel 2.1. 4.1 Aturan-aturan dalam DFD Perintah yang berhubungan dengan pengelolaan file/direktori Operator Aritmatika Operator perbandingan Operator logika Tipe data pada Java Operator aritmatika pada Java Tipe data pada C++. Tabel 9.2. Operator pada C++. Kelas, fungsi, dan parameter pada aplikasi persediaan toko buku Tabel dan atribut pada Basis Data Penjualan Buku Tabel, atribut, tipe data dan constraint/domain pada Basis Data Penjualan Buku Tabel, kolom, tipe data yang akan dibuat Daftar attribute TYPE untuk Ordered list dan Unordered list Bagian-bagian pada tag Table Attribute-attribute tag Jenis-jenis operator 7.1. 7.2. 7.3. 8.1. 8.2. 9.1. 9.2. 9.3. 11.1. 11.2. 12.1. 13.1. 13.2. 13.3. 21.1. Halaman 30 85 153 154 154 180 183 226 228 271 271 338 354 358 362 382 Rekayasa Perangkat Lunak C9