Perancangan Perangkat Lunak
UNIFIED MODELLING LANGUAGE
Pengantar • Unified Modelling Language (UML) adalah sebuah "bahasa" yang telah menjadi standar , g dalam industri untuk visualisasi, merancang dan mendokumentasikan sistem piranti lunak. UML menawarkan sebuah standar untuk UML menawarkan sebuah standar untuk merancang model sebuah sistem.
M d lK Model Konseptual t l • Building block (blok pembangun) sintaks (dan semantik dari sintaks) dari bagian model dengan UML • Rules g model dari aturan untuk membangun berbagai bagian model • C Common mechanism h i mekanisme pemodelan umum yang diterapkan di seluruh UML
Bl k P Blok Pembangun b pada d UML • Things abstraksi dari apa yang akan dimodelkan • Relationship hubungan antar abstraksi (things) • Diagrams mengelompokkan kumpulan sejumlah l kk k l j l h abstraksi yang dihubungkan 5
1 Things 1. • Structural (berpadanan dengan kata benda) merepresentasikan aspek statis sistem merepresentasikan aspek statis sistem • Behavioural (berpadanan dengan kata kerja) merepresentasikan aspek dinamis sistem • G Grouping i menyatakan pengelompokkan sejumlah abstraksi dengan organisasi tertentu • Annotational memberikan keterangan atas suatu abstraksi
6
Structural Things Class
Window origin size open( ) close( ) move( )
Collaboration
Chain of Responsibility
Place Order IWindow
Use Case
Active Class
Event Mgr th d thread time suspend( ) flush( ) stop( )
listbox
Node
WebServer
Component
Interface 7
Structural Things • Class deskripsi dari kumpulan objek dengan atribut, operasi, relasi, dan semantik yang sama dan semantik yang sama • Interface koleksi operasi yang menyatakan layanan dari kelas/komponen • Collaboration mendefinisikan interaksi dan merupakan kumpulan peran dan mendefinisikan interaksi dan merupakan kumpulan peran dan elemen yang bekerja sama untuk menyediakan perilaku kooperatif agregat • Use case deskripsi dari himpunan langkah aksi yang dilakukan sistem yang menghasilkan luaran kepada aktor tertentu yang menghasilkan luaran kepada aktor tertentu 8
Structural Things • Active Class Kelas yang mempunyai satu atau lebih proses / y g p y p thread sehingga dapat memulai aktivitas kontrol • Component Bagian fisik sistem yang dapat diganti‐ganti yang sesuai dan menyediakan realisasi interface tertentu • Node N d Elemen fisik yang ada saat run time dan mewakili sumber daya komputasi (kemampuan memori dan sumber daya komputasi (kemampuan memori dan pemroses)
B h i Behavioral l Thi Things Bagian dinamik dari model UML Biasanya terhubung dengan model struktural. Ditulis dalam kata kerja kerja. Ada 2 macam: Interaksi perilaku yang terdiri dari sekumpulan pesan yang saling dipertukarkan antar sekumpulan objek dalam konteks tertentu untuk mencapai tujuan tertentu di l display State Machine perilaku yang menspesifikasikan urutan state dari objek atau interaksi yang perilaku yang menspesifikasikan urutan state dari objek atau interaksi yang terjadi selama hidup objek tersebut dalam menyikapi event dan tanggapannya terhadap event‐event tersebut Idle
Waiting
10
P k Package Diagram Di • Biasanya dipakai pada use case diagram atau class diagram • Packages digambarkan sebagai sebuah direktori (file folders) yang berisi model‐model elemen • Walaupun package secara resmi bukanlah diagram UML, namun kegunaannya cukup signifikan kegunaannya cukup signifikan • Packages dibuat untuk : – Menggambarkan high level overview kebutuhan sistem – Menggambarkan high level overview design – Memecah sebuah diagram yang mempunyai banyak bubbles – Mengorganisasikan source code programming Mengorganisasikan source code programming • Digambarkan dengan lambang
P k Package Diagram Di Class diagram Package
Use case diagram Package
Grouping & Annotational Things Packages ‐ Mekanisme untuk mengorganisasi elemen ‐ Konseptual, hanya ada pada waktu pengembangan Konseptual, hanya ada pada waktu pengembangan ‐ Berisi structural dan behavioral things ‐ Dapat bersarang p g , , y ‐ Variasi package: framework, model, & subsystem.
Meeting Scheduler Notes Elemen UML (Note) yang digunakan untuk menerangkan elemen lain pada Elemen UML (Note) yang digunakan untuk menerangkan elemen lain pada model
flexible drop-out dates 13
2 Relationships 2. 4 jenis • Dependensi • Asosiasi A i i • Generalisasi • Realisasi
14
Relationships Dependensi merupakan hubungan semantik antara 2 things sedemikian sehingga perubahan pada satu thing mengakibatkan perubahan pada thing lainnya perubahan pada satu thing mengakibatkan perubahan pada thing lainnya Asosiasi merupakan hubungan struktural yang menggambarkan himpunan link antar objek employer
employee
0..1
*
Aggregasi jenis khusus dari asosiasi (menyatakan whole part) jenis khusus dari asosiasi (menyatakan whole part) 15
Relationships Association ‐‐ Use Case Diagram Association • Ada 4 jenis relasi yang bisa timbul pada use case diagram – Association antara actor dan use case – Association antara use case – Generalization/Inheritance antara use case – Generalization/Inheritance antara actors Generali ation/Inheritance antara actors • Associations bukan menggambarkan aliran data/informasi • Associations digunakan untuk menggambarkan bagaimana Associations digunakan untuk menggambarkan bagaimana actor terlibat dalam use case
R l ti Relationships hi Association antara actor dan use case •
•
•
Ujung panah pada association antara actor dan use case mengindikasikan siapa/apa yang meminta interaksi dan bukannya mengindikasikan aliran data Sebaiknya gunakan garis tanpa panah untuk association antara actor dan use case
association antara actor dan use case yang menggunakan panah terbuka untuk mengindikasikan bila actor berinteraksi secara pasif dengan system anda. Beli Barang Konsumen
Bayar
Kasir
Association antara use case •
<
> – termasuk didalam use case lain (required) / (diharuskan) – Pemanggilan gg use case oleh use case lain – contohnya adalah Pemanggilan sebuah fungsi program – Gambarkan association <> secara horizontal – Tanda panah terbuka harus terarah ke sub use case – Tidak boleh actor dihubungkan pada use case <> Buka Rekening
<>
<> Nasabah catat data pribadi
Buka Rekening
Nasabah
Catat Data Pribadi <>
catat data pribadi
Buka Rekening
Nasabah
<>
catat data pribadi
Association antara use case • <<extend>> << t d>> – Perluasan dari use case lain jika kondisi atau syarat terpenuhi – Kurangi penggunaan association Extend ini, terlalu banyak pemakaian g p gg y p association ini membuat diagram sulit dipahami. – Tanda panah terbuka harus terarah ke parent/base use case – Gambarkan association extend secara vertical (picture extending use Gambarkan association extend secara vertical (picture extending use case below than base/parent use case) – Tidak boleh actor dihubungkan pada use case <<extend>> Buka Rekening <<extend>>
<<extend>> Nasabah
Buka Deposito
Buka Rekening
Nasabah
<<extend>>
Buka Deposito
R l ti Relationship hi Generalisasi Relasi antar objek yang memiliki hubungan general‐spesial
Realisasi Relasi semantik antara 2 elemen dimana 1 elemen melaksanakan apa yang diharapkan dari elemen lain. Biasanya antara antarmuka dan kelas yang merealisasikannya, atau pada use case dan kolaborasi yang y , p y g merealisasikannya
20
R l ti Relationships hi Generalization/inheritance • Generalization/inheritance digambarkan dengan sebuah garis berpanah tertutup pada salah satu ujungnya yang menunjukkan lebih umum tertutup pada salah satu ujungnya yang menunjukkan lebih umum • Harus digambarkan secara vertikal Generalization/inheritance antara use case • Dibuat ketika ada sebuah keadaan yang lain/perlakuan khusus • Inheriting use case dibawah base/parent use case
R l ti Relationships hi Generalization/inheritance antara actor • Dibuat ketika ada sebuah actor baru terbentuk dan b k k d b h b b kd mempunyai atribut dan methode yang sama dengan actor yang sudah ada d h d • Inheriting actor dibawah base/parent actor
Nasabah
R l ti Relationships hi Generalization/inheritance Contoh : Contoh :
3 Diagrams 3. • Representasi grafik dari sekumpulan elemen. • Direpresentasikan dalam sebuah graf dimana node adalah thing dan busur adalah behavior • Ada 9 diagram: Class Diagram; Object Diagram; Use case Diagram Sequence Diagram; Collaboration Diagram; Statechart Diagram Activity Diagram; Component Diagram; Deployment Diagram
24
U C Use Case Di Diagram • Use case diagram menggambarkan f fungsionalitas yang diharapkan dari sebuah i lit dih k d i b h sistem. Yang ditekankan adalah “apa” yang diperbuat sistem, dan bukan “bagaimana”. p Sebuah use case merepresentasikan sebuah interaksi antara aktor dengan sistem.
U C Use Case Di Diagram • Menggambarkan kebutuhan sistem dari sudut pandang user • Mengfokuskan pada proses komputerisasi (automated processes) • Menggambarkan hubungan antara use case dan actor • Use case menggambarkan proses sistem (kebutuhan sistem dari sudut pandang user)
U C Use Case Di Diagram • Secara umum use case adalah: – Pola perilaku sistem – Urutan transaksi yang berhubungan yang dilakukan k b h b dl k k oleh satu actor • Use case diagram terdiri dari Use case diagram terdiri dari – Use case – Actors – Relationship – System boundary boxes (optional) System boundary boxes (optional) – Packages (optional) • Every actor is involved with at least one use case, and y , every use case is involved with at least one actor
U C Use Case Di Diagram Use Case - Use Case Diagram • •
• • • •
Use case diberi nama yang menyatakan apa hal yang dicapai dari hasil interaksinya dengan actor. Use case dinotasikan dengan gambar (horizontal ellipse)
Use case biasanya menggunakan verb Nama use case boleh terdiri dari beberapa kata dan tidak boleh ada 2 use case yang memiliki nama yang sama Sebuah use case bisa mempunyai dokumentasi Gunakan dengan lambang dibawah ini dan ditarik dengan garis putus tanpa panah
U C Use Case Di Diagram • Letakkan use case utama anda pada pojok kiri atas dari diagram (in western culture people read from left to right diagram ( right, top to bottom, starting in the top-left corner) • Use case diagram tidak terpengaruh urutan waktu, Use case diagram tidak terpengaruh urutan waktu meskipun demikian supaya mudah dibaca perlu penyusunan use case penyusunan use case (increase the readability of your use case diagram by arranging use cases to imply mp y timing, m g, one such way y is to stack them. m So that the use case that typically occur first are shown above those that appear later)
U C Use Case Di Diagram Actor ‐ Use Case Diagram • Actor menggambarkan orang, sistem atau external entitas / stakeholder yang menyediakan atau menerima informasi dari t k h ld di k t i i f id i system • Actor memberi input atau menerima informasi dari system • Actor biasanya menggunakan Noun A bi k N • Actor digambarkan dengan gambar stick figure atau dengan gambar visual atau
atau
dll
• Tidak boleh ada komunikasi langsung antar actor (Actors don’t interact with one another )
U C Use Case Di Diagram • Indikasi <<system>> untuk sebuah actor yang merupakan sebuah system merupakan sebuah system
• Adanya Adanya actor bernama actor bernama “Time” Time yang mengindikasikan yang mengindikasikan scheduled events (suatu kejadian yang terjadi secara periodik/bulanan)
U C Use Case Di Diagram
•
Letakkan actor utama anda pada pojok kiri atas dari diagram (in western culture people read from left to right, top to bottom) (place your primary Use case in the top left corner of the diagram because your primary actor is often directly involved with your primary/critical use case) Actor jangan digambarkan ditengah‐tengah use cases
•
Actors menggambarkan sebuah tugas/peran dan bukannya posisi sebuah jabatan
• •
(Actors model roles, not positions. A good indication that you are modeling positions instead of
roles is a use case diagram depicting several actors with similar names that have associations to the same use case)
Contoh: Sistem Registrasi g Universitas The UTD wants to computerize its registration system – The Registrar sets up the curriculum for a semester • One course may have multiple course offerings – Students select four (4) primary courses and two (2) alternate courses – Once a student registers for a semester, the billing system is notified so the student may be billed for the semester – Students may use the system to add/drop courses for a period of time after registration – Professors use the system to set their preferred course Professors use the system to set their preferred course offerings and receive their course offering rosters after students register – Users of the registration system are assigned passwords which U f th i t ti t i d d hi h are used at logon validation 33
Contoh: Sistem Registrasi Universitas • Aktor adalah seseorang atau sesuatu yang berinteraksi dengan sistem yang dikembangkan
Professor Registrar
St d t Student
Billing System 34
Contoh: Sistem Registrasi Universitas
Sebuah use case menunjukkan perilaku sistem
Aktor: – Registrar ‐‐ mengelola kurikulum – Professor – menentukan MK yang akan ditawarkan dan meminta daftar MK – Student – mengelola jadwal – Billing System – g y menerima informasi tagihan g
Maintain Curriculum
Request Course Roster
Maintain Schedule
35
Contoh: Sistem Registrasi g Universitas • Use case diagrams Request Course Roster Professor
Set Course Offerings
Student Maintain Schedule
Billing System Maintain Curriculum Registrar 36
R li Realisasi iU Use C Case • Diagram use case menggambarkan outside view dari sistem • Inside view dari sistem digambarkan dengan diagram interaksi • Diagram interaksi menggambarkan bagaimana use case direalisasikan sebagai interaksi antar sekumpulan objek g p j dengan mempertukarkan message. Diagram interaksi menggambarkan pandangan dinamis dari sistem • Ada 2 jenis: – Sequence Diagram Sequence Diagram – Collaboration Diagram
S Sequence Di Diagram • Sequence diagram menggambarkan interaksi antar objek di dalam & di sekitar sistem (termasuk pengguna, display, ( p gg , p y, dan sebagainya) berupa message yg digambarkan terhadap waktu. Sequence diagram terdiri atas dimensi vertikal (waktu) dan dimensi horizontal (objek‐objek yang terkait). • Sequence diagram biasa digunakan untuk menggambarkan rangkaian langkah‐langkah yang dilakukan sebagai respons dari sebuah event untuk menghasilkan output tertentu. Diawali dari apa yang men‐trigger aktivitas tersebut, proses dan perubahan apa saja yang terjadi secara internal d dan output apa yang dihasilkan t t dih ilk
Sequence Diagram : Student
registration form
registration manager
math 101
math 101 section 1
1: fill in info 2: submit 3: add course(Sue, math 01) 4: are you open? 5: are you open? 6: add (Sue) 7: add (Sue)
39
C ll b Collaboration ti Di Diagram • Collaboration diagram juga menggambarkan i t ki t interaksi antar objek seperti sequence bj k ti diagram, tetapi lebih menekankan pada peran masing‐masing objek dan bukan pada waktu p y p penyampaian message. g Setiap message memiliki sequence number, di mana message dari level tertinggi memiliki mana message dari level tertinggi memiliki nomor 1. Messages dari level yang sama memiliki prefiks yang sama memiliki prefiks yang sama.
Collaboration Diagram 1: set course info 2: process
course form : CourseForm
3: add course
: Registrar
theManager : CurriculumManager
aCourse : Course 4: new course
41
Class Diagram • Sebuah class diagram menunjukkan keberadaan class‐class dan relasinya • Elemen‐elemen class diagram : class, relasi, multiplicity, dan role names • Sebuah class adalah abstraksi dari sekumpulan objek yang memiliki struktur yang sama, perilaku yang sama, relasi yang sama dan semantik yang sama d ik • Beberapa class muncul pada sequence diagram atau collaboration diagram collaboration diagram • Harus dibuat standar penamaan class, misalnya: class ditulis dalam kata benda dengan huruf kapital di awal kata dalam kata benda dengan huruf kapital di awal kata 42
Cl Class Di Diagram • Class adalah sebuah spesifikasi yang jika diinstansiasi akan menghasilkan sebuah objek dan merupakan inti dari pengembangan dan desain berorientasi objek. Class menggambarkan keadaan (atribut/properti) suatu sistem, sekaligus menawarkan layanan untuk i k li k l k memanipulasi keadaan tersebut (metoda/fungsi). • Class diagram menggambarkan struktur dan deskripsi class, package dan objek beserta hubungan satu sama lain seperti containment, pewarisan, asosiasi, dan lain‐lain.
Cl Class Di Diagram Class memiliki tiga area pokok : 1 Nama (dan stereotype) 1. Nama (dan stereotype) 2. Atribut 3. Metoda 3. Metoda Atribut dan metoda dapat memiliki salah satu sifat berikut : Atribut dan metoda dapat memiliki salah satu sifat berikut : • Private, tidak dapat dipanggil dari luar class yang bersangkutan • Protected, hanya dapat dipanggil oleh class yang bersangkutan Protected hanya dapat dipanggil oleh class yang bersangkutan dan anak‐anak yang mewarisinya • Public, dapat dipanggil oleh siapa saja , p p gg p j
Class Diagram ScheduleAlgorithm
RegistrationForm RegistrationManager
Course Student
Professor CourseOffering
45
Class Diagram ScheduleAlgorithm
RegistrationForm RegistrationManager addStudent(Course, StudentInfo)
Course name numberCredits
Student
open() addStudent(StudentInfo)
name major
Professor name tenureStatus
CourseOffering location open() addStudent(StudentInfo)
46
Diagram Objek Menunjukkan sekumpulan objek dan relasinya Harry (Student) Name: “Harry Mat” Major: CS
Sue (Professor) Name: “Sue Becker” tenureStatus: true
47
St t h t Di Statechart Diagram • Statechart diagram menggambarkan transisi d dan perubahan keadaan (dari satu state ke b h k d (d i t t t k state lainnya) suatu objek pada sistem sebagai akibat dari stimuli yang diterima. Pada y g umumnya statechart diagram menggambarkan class tertentu (satu class dapat memiliki lebih dari satu statechart dapat memiliki lebih dari satu statechart diagram).
Statechart Diagram • Terdiri dari status, transisi, kejadian, dan aktivitas
Idle tooHot(desTemp)
tooCold(desTemp)
atTemp
atTemp
C li Cooling
H ti Heating tooCold(desTemp) tooHot(desTemp) 49
A i i Di Activity Diagram • Activity diagrams menggambarkan berbagai alir anaktivitas dalam sistem yang sedang dirancang, bagaimana masing‐ masing alir berawal decision yang mungkin terjadi dan masing alir berawal, decision yang mungkin terjadi, dan bagaimana mereka berakhir. Activity diagram juga dapat menggambarkan proses paralel yang mungkin terjadi pada beberapa eksekusi beberapa eksekusi. • Activity diagram merupakan state diagram khusus, di mana y g p g , sebagian besar state adalah action dan sebagian besar transisi di‐trigger oleh selesainya state sebelumnya (internal p processing). Oleh karena itu activity diagram tidak g) y g menggambarkan behaviour internal sebuah sistem (dan interaksi antar subsistem) secara eksak, tetapi lebih menggambarkan proses‐proses menggambarkan proses proses dan jalur dan jalur‐jalur jalur aktivitas dari aktivitas dari level atas secara umum.
Di Diagram Akti Aktivitas it Prepare for Speech
Swimlanes
Decompress
Gesture() Synch mouth()
Stream audio()
Cleanup
51
Di Diagram K Komponen • Component diagram menggambarkan struktur dan hubungan antar komponen piranti lunak, termasuk ketergantungan (dependency) di antaranya. • Komponen piranti lunak adalah modul berisi code, b ik b i i baik berisi source code maupun binary code, baik d bi d b ik library maupun executable, baik yang muncul pada compile time, link time, maupun run time. Umumnya compile time, link time, maupun run time. Umumnya komponen terbentuk dari beberapa class dan/atau package, tapi dapat juga dari komponen‐komponen yang lebih kecil. l bih k il Komponen dapat juga berupa interface, yaitu kumpulan layanan yang disediakan sebuah kumpulan layanan yang disediakan sebuah komponen untuk komponen lain.
Diagram Komponen <<
file
>>
{version=4.1}
Signal.h
<<
file
<<
>>
file
>>
I h Irq.h
>>
{version=4.1}
Interp cpp Interp.cpp
<<
file
Signal.cpp
<<
file
>>
D i Device.cpp 53
D l Deployment t Diagram Di • Deployment/physical diagram menggambarkan detail bagaimana komponen di‐deploy dalam infrastruktur sistem, di mana komponen akan terletak (pada mesin, server atau piranti keras apa), bagaimana kemampuan jaringan pada l k it lokasi tersebut, spesifikasi server, dan hal‐hal lain yang b t ifik i d h l h ll i bersifat fisikal • Sebuah node adalah server, workstation, atau piranti keras Sebuah node adalah server workstation atau piranti keras lain yang digunakan untuk men‐deploy komponen dalam lingkungan sebenarnya. Hubungan antar node (misalnya g g y g ( y TCP/IP) dan requirement dapat juga didefinisikan dalam diagram ini.
D l Deployment t Diagram Di • Deployment diagram menunjukkan konfigurasi perangkat keras dan komponen‐komponen perangkat keras dan komponen komponen PL yang PL yang ada di dalamnya Server Aplikasi
Server Basisdata
PC Klien 55
D l Deployment t Diagram Di
R l Rules Rules diperlukan untuk mendefinisikan well‐formed model UML memiliki aturan‐aturan untuk: • Penamaaan: bagaimana memberi nama pada class, relasi, dan diagram • Scope: Konteks yang dapat memberikan makna yang lebih spesifik bagi thing {akan dibahas pada diagram kelas} • Visibility: berkaitan Vi ibili b k i d dengan akses k sebuah b h elemen l oleh l h elemen lain • Integrity: bagaimana Integrity: bagaimana things berelasi secara konsisten • Eksekusi: Bagaimana transformasi diagram 57
C Common M Mechanism h i • Spesifikasi: Untuk setiap model perlu didefinisikan penjelasan tentang sintaks dan semantik dari model • Adornment: Notasi‐notasi pada UML mudah dan lengkap, gg y g g j sehingga model yang didefinisikan bisa dibaca dengan jelas • Common division: selalu terdapat pasangan notasi/istilah/konsep untuk memodelkan sistem, mis.class notasi/istilah/konsep untuk memodelkan sistem, mis.class dan objek, komponen dan instan komponen, use case dan realisasi use case, antarmuka dan implementasi, dan lain‐lain • Extensibility: memberi keleluasaan untuk memperluas bahasa secara terkontrol
Extensibility Stereotypes digunakan untuk mengklasifikasikan dan memperluas sosiasi,relasi pewarisan, kelas, dan komponen • Nama ditulis dalam <<stereotype>> Nama ditulis dalam <<stereotype>> • Contoh: – Class stereotypes: boundary, control, entity, utility, exception yp y, , y, y, p – Inheritance stereotypes: uses and extends – Component stereotypes: subsystem Tagged values — mendefinisikan informasi pada elemen anObject:ClassA {l {location=server) ti )
Constraints — memperluas semantik dari blok pembangun UML • {if Order.customer.credit.Rating {if Order customer credit Rating is “poor” then Order.isPrepaid is “poor” then Order isPrepaid must be true}
59
Penggunaan Notasi UML – Menggambarkan batasan sistem dan fungsi‐fungsi y g g utamanya dengan diagram use case – Buat realisasi use case dengan diagram interaksi – Gambarkan struktur statik sistem dengan diagram kelas Gambarkan struktur statik sistem dengan diagram kelas – Modelkan perilaku objek dengan state transition diagram g – Gambarkan arsitektur implementasi dengan diagram komponen dan deployment – Perluas fungsionalitas dengan stereotypes
60