UML Tutorial
Source UML tutorial
UML (Unified Modeling Languange)
Uml adalah sekumpulan praktik rekayasa terbaik yang terbukti efektif dalam memodelkan system yang besar dan kompleks dan merupakan bagian yang sangat penting dari pengembangan perangkat lunak berorientasi objek UML. UML berfungsi membantu tim untuk berkomunikasi, mengeksplorisasi desain potential, dan memvalidasi desain arsitektur perangkat lunak.
Tujuan utama UML adalah menyediakan anotasi standar yang bisa digunakan oleh semua metode berbasis objek dan mengintegrasikan elemen terbaik dari notasi-notasi sebelumnya. UML dirancang untuk berbagai aplikasi, termasuk analisis sistem terdistribusi, desain sistem, dan penerapan (deployment). Oleh karena itu, UML menawarkan konstruksi yang bervariasi untuk berbagai sistem dan kegiatan.
Diagram UML dapat dibagi menjadi dua jenis utama: diagram struktur dan diagram perilaku. Diagram struktur menggambarkan aspek statis dari sistem, sedangkan diagram perilaku fokus pada dinamika atau interaksi dalam sistem. Berikut adalah Beberapa Macam dari diagram struktur:
Composit struktur diagram
Diagram struktur komposit digunakan untuk menggambarkan struktur internal dari beberapa kelas dan menunjukkan interaksi di antara mereka. Dalam diagram ini, Anda dapat merepresentasikan kelas bagian dalam dan menunjukkan hubungan antara kelas serta dalam kelas itu sendiri. Dengan kata lain, diagram struktur komposit menunjukkan bagian-bagian internal dari suatu kelas. Nama bagian biasanya dibentuk dengan pola: nama bagian diikuti oleh titik dua, kemudian jenis bagian, dan multiplicity dinyatakan di dalam tanda kurung kotak. Kelas-kelas yang digabungkan merupakan bagian dari suatu kelas, tetapi bagian tersebut tidak selalu berupa kelas. Bagian adalah elemen apa pun yang digunakan untuk membentuk kelas yang memuatnya.
Misalnya, kita sedang memodelkan sistem untuk toko online di mana pelanggan dapat bergabung dengan program loyalitas yang memberikan mereka keuntungan, seperti pengiriman diskon. Untuk memungkinkan fitur tersebut, objek customer diperluas sehingga sekarang kita memiliki regular customer dan member of loyalty program.
Diagram struktur komposit memberikan gambaran yang lebih jelas tentang store manager dari sudut pandang internal, bukan dari seluruh sistem. Store manager langsung memuat dua jenis objek, yaitu customer dan item, seperti yang ditunjukkan oleh dua panah komposisi pada diagram kelas. Dalam diagram struktur komposit ini, tipe kedua bagian dinyatakan sebagai customer, karena toko memperlakukan kedua objek tersebut sebagai objek customer. Kita juga melihat adanya konektor yang menunjukkan hubungan antara item dan order. Meskipun order tidak langsung terdapat di dalam kelas store manager, kita bisa menunjukkan hubungan dengan bagian-bagian yang tertanam di objek yang digabungkan olehnya.
Deployment diagram
Diagram deployment dalam UML sangat penting untuk merepresentasikan topologi fisik suatu sistem saat runtime. Diagram ini menggambarkan bagaimana komponen perangkat lunak, node perangkat keras, dan saluran komunikasi diatur dan berinteraksi. Diagram ini sangat berguna untuk merencanakan arsitektur sistem embedded, sistem client-server, dan sistem terdistribusi. Berikut adalah penjelasan cara kerja diagram deployment untuk berbagai sistem:
- Sistem Embedded Identifikasi perangkat dan node yang unik untuk sistem tersebut. Gunakan mekanisme perluasan UML, seperti stereotype, untuk membedakan komponen perangkat keras dan perangkat lunak secara visual. Modelkan hubungan antara node perangkat keras dan proses perangkat lunak.
- Sistem Client-Server Modelkan prosesor klien dan server serta perangkat khusus seperti pembaca kartu kredit. Tampilkan topologi perangkat keras, dengan menyoroti hubungan antara node klien dan server serta komponen perangkat lunak yang mereka host.
- Sistem Terdistribusi Representasikan perangkat komunikasi jaringan pada tingkat detail yang cukup untuk analisis kinerja. Gunakan diagram paket UML untuk mengelompokkan node secara logis dan mensimulasikan topologi jaringan.
Packet diagram
Diagram package biasanya digunakan ketika perlu untuk mengelompokkan elemen-elemen yang terkait dan menentukan lingkup nama mereka, atau ketika perlu memvisualisasikan dependensi antar bagian sistem. Diagram ini juga berguna untuk memberikan dukungan analisis atau menentukan urutan kompilasi. Diagram package digunakan untuk menyusun elemen-elemen sistem tingkat tinggi. Saat memodelkan diagram package, ada beberapa hal yang perlu diingat:
- Package adalah mekanisme UML untuk mengelompokkan elemen, termasuk package lain.
- Setiap package memiliki namespace sendiri, di mana semua nama harus unik.
- Setiap elemen model hanya boleh berada di dalam satu package, dan packages membentuk hierarki.
Stereotype adalah klasifikasi tinggi suatu objek yang memberikan gambaran tentang apa objek itu. Kelas-kelas bisa dikelompokkan berdasarkan stereotype, yang ditulis dalam tanda sudut di atas nama kelas. Stereotype memungkinkan kita untuk memperluas UML agar sesuai dengan kebutuhan pemodelan kita.
Profile diagram
Diagram profil adalah salah satu diagram struktural UML yang terkenal karena menyediakan mekanisme perluasan umum untuk menyesuaikan model UML bagi domain dan platform tertentu. Profil didefinisikan menggunakan stereotip, definisi nilai tag, dan batasan yang diterapkan pada elemen model tertentu, seperti kelas, atribut, operasi, dan tindakan. Sebuah profil adalah sekumpulan ekstensi yang secara bersama-sama mengonfigurasi UML untuk domain tertentu, misalnya dirgantara, medis, atau keuangan, atau untuk platform spesifik seperti J2EE atau .NET. Diagram profil memiliki tiga jenis mekanisme ekstensi utama: stereotip, tag, dan batasan.
- Stereotip memungkinkan kita memperluas kosakata UML. Stereotip digunakan untuk memperkenalkan blok bangunan baru yang sesuai dengan bahasa domain Anda dan terlihat primitif. Misalnya, ketika memodelkan jaringan, Anda mungkin membutuhkan anotasi untuk router, switch, hub, dll. Stereotip memungkinkan Anda membuat simbol-simbol ini muncul sesederhana mungkin.
- Tag digunakan untuk memperluas properti UML sehingga Anda dapat menambahkan informasi tambahan ke spesifikasi elemen model. Ini memungkinkan Anda menentukan pasangan kata kunci-nilai pada model, di mana kata kunci adalah atribut. Nilai tag ditampilkan secara grafis sebagai string yang ditempatkan di dalam kurung kurawal. Misalnya, tag bisa digunakan untuk menambahkan properti ke model seperti manajemen versi, kontrol konfigurasi, atau kepengarangan.
- Batasan digunakan untuk menentukan semantik atau kondisi yang harus selalu dipenuhi. Batasan ditampilkan sebagai string di dalam tanda kurung siku yang diletakkan di sebelah elemen terkait. Misalnya, batasan dapat ditempatkan pada atribut atau asosiasi untuk memastikan informasi seperti waktu respon pada sistem waktu nyata.
Profil UML dalam UML 2.0 atau lebih tinggi memungkinkan Anda untuk menggabungkan beberapa profil secara dinamis sehingga profil-profil tersebut dapat diterapkan pada model yang sama. Ekstensi stereotip ditunjukkan dengan panah solid dan kepala panah yang diisi yang mengarah dari stereotip ke meta kelas. Stereotip dapat ditampilkan dalam bentuk teks atau grafik, dan sering kali digunakan untuk memodelkan infrastruktur perangkat lunak seperti MVC (Model-View-Controller).
Untuk menggunakan stereotip dalam aplikasi tertentu, Anda harus mengintegrasikan profil yang berisi stereotip tersebut. Panah putus-putus digunakan untuk menandakan penerapan profil pada paket tertentu, yang kemudian memungkinkan elemen-elemen dalam profil tersebut tersedia untuk digunakan dalam paket terkait.
Class diagram
Diagram kelas menggambarkan struktur sistem dengan mendeskripsikan kelas-kelas, atribut-atributnya, metode-metode, dan hubungan antar kelas. kelas adalah template untuk membuat objek, serta merepresentasikan atribut awal objek dan metode perilakunya. Setiap atribut memiliki tipe, dan setiap metode memiliki tanda tangan (signature), tetapi dalam diagram kelas, hanya nama kelas yang wajib ditampilkan. Hal ini masuk akal karena bahkan seorang ahli pun tidak bisa menebak apa yang dimaksud oleh sebuah kotak tanpa nama.
Bagian bagian terpenting dala sebuah class digram meliputi: nama kelas, atribut kelas, metode kelas. Dalam UML class terdapat sebuah accsess classifier. Yang menetukkan Tingkat aksebilitas adalah:
- Plus(+) menunjukkan public (dapat diakses oleh siapa saja)
- Minus (-) menunjukkan private (hanya dapat diakses oleh kelas itu sendiri)
- Hash (#) menunjukkan protected (dapat diakses oleh kelas dan turunannya)
- Tilde (~) menunjukkan packet local (dapat diakses oleh kelas dalam paket yang sama).
- In:Parameter digunakan sebagai input untuk metode dan nilainya tidak diubah oleh metode.
- out: Parameter digunakan untuk menerima output dari metode, dengan nilai yang dapat diubah oleh metode.
- in-Out: Parameter digunakan sebagai input sekaligus dapat diubah oleh metode untuk dikembalikan sebagai output.
- Object diagram
Component Diagram
- Provided interface: Digambarkan dengan lingkaran penuh di ujung dan disebut sebagai lollipop, menunjukkan antarmuka yang disediakan oleh komponen kepada sistem.
- Required interface: Ditandai dengan setengah lingkaran, menunjukkan antarmuka yang dibutuhkan oleh komponen untuk bekerja.
Activity Diagram
- Control Flow / Object Flow
- Decision Node
- Merge Node
- Fork Node
- Join Node
- Object
- Final Node
- Swim Lane
Use case diagram
- Aktor: Mewakili entitas yang berinteraksi dengan sistem. Seorang aktor memainkan peran tertentu dalam proses yang berbeda dan dapat berinteraksi dengan beberapa use case. Yang penting dalam diagram ini adalah peran aktor, bukan pengguna sebagai individu. Misalnya, seorang profesor bisa bertindak sebagai dosen di satu konteks dan sebagai peneliti di konteks lain.
- Use Case: Mewakili tindakan atau proses spesifik yang dilakukan oleh sistem sebagai respons terhadap interaksi aktor. Mereka menggambarkan "apa" yang dilakukan sistem, bukan "bagaimana" implementasinya. Setiap use case biasanya merepresentasikan fungsi yang menghasilkan hasil yang berarti.
- Link Komunikasi: Mewakili hubungan antara aktor dan use case. Mereka menunjukkan bahwa aktor memulai interaksi dengan sistem untuk memicu use case.
- Batasan Sistem: Diagram use case dapat mencakup seluruh sistem atau modul spesifik di dalamnya. Misalnya, dalam sistem ERP (Enterprise Resource Planning) besar, setiap modul (seperti SDM atau Akuntansi) bisa membentuk batasannya sendiri untuk berbagai use case.
State mechine diagram
- Initial State: "Start"
- State 1: "Cart" – pengguna menambahkan item ke keranjang belanja.
- State 2: "Checkout" – pengguna memilih untuk melakukan pembayaran.
- State 3: "Order Placed" – pengguna berhasil melakukan pemesanan.
- Final State: "Order Completed" – pesanan selesai diproses.
Sequence diagram
Communication diagram.
- Memodelkan pesan yang dikirimkan antara objek atau peran yang menyediakan fungsionalitas dari use case dan operasi.
- Mendokumentasikan mekanisme di dalam desain arsitektur sistem.
- Menangkap interaksi yang menunjukkan pesan yang terjadi di masa lalu antara objek dan peran dalam kolaborasi.
- Memodelkan skenario alternatif dalam use case atau operasi yang melibatkan kolaborasi berbagai objek dan interaksi.
- Mendukung identifikasi objek, kelas, dan atribut melalui pesan yang terlibat dalam use case.
Timing diagram
Timing diagrams adalah diagram interaksi UML yang digunakan ketika tujuan utama dari diagram adalah menunjukkan interval antara perubahan state dari berbagai objek. Timing diagrams berfokus pada kondisi yang berubah di dalam dan antar lifelines di sepanjang sumbu waktu, dan menggambarkan perilaku baik dari classifier individu maupun interaksinya, dengan fokus pada waktu kejadian yang menyebabkan perubahan pada kondisi yang dimodelkan. Transisi dari satu state ke state lain adalah perubahan level lifeline selama periode waktu ketika objek berada dalam state tertentu. Timeline berjalan sejajar dengan state tersebut. Perubahan state ditampilkan sebagai perubahan vertikal dari satu level ke level lain. Alasan perubahan, seperti dalam state diagram atau sequence diagram, biasanya adalah penerimaan pesan atau permintaan event yang menyebabkan perubahan (disebut stimulus). Namun, perubahan juga bisa terjadi secara otomatis oleh sistem, yang dipicu oleh berlalunya waktu.
Komentar
Posting Komentar