Can you please help me find a detailed tutorial on this topics:
- UML
- Behavior Diagrams
- Use Case Diagrams
- Activity Diagrams
- Structure Diagrams
- Class Diagram
- Interaction Diagrams
- Sequence Diagram
- Communication Diagram
I'm really a newbie and I want know what are the ideas in using UML diagrams, there differences, and the tools (like UMLet) that are ideal for novices like me.
First and for most let me discuss UML and Use Cases.
UML is just a graphical way of describing software systems.
There are two types of UML namely:
- UML Sketching - here you only want to communicate an idea and go through different alternative approaches. It's not specific but it only gives the basic ideas.
- UML Blueprint - This is a very detailed type of modeling in which everything is well laid out and there is a definite time of completion.
Next up is the UML Development Process.
- Waterfall Model - The development process must follow the Analysis, Design, Coding, and Testing Process strictly. Meaning you can't do the coding without the design, and so on. You must start with the Analysis, Design, Coding and Testing (ADCT) Process. Overlapping within this processes is not allowed.
- Iterative (Most Common) - The iterative way is kinda different from the waterfall model in a sense that it is more flexible. You can divide the system into pieces and run the ADCT Process on each piece. Meaning you will not do Analysis just once, which will make your system flexible to changes. No wonder this is a more common type of approach.
Then there's the UML Planning Process
Predictive Planning - outcome is known for the whole duration of the project and everything should run smoothly with all the stakeholders involve, 'on the same page'.
If you can easily list all requirements and you are pretty sure that it will not change, Use predictive Planning.
Adaptive Planning (Agile Development) - here the developer continually works with the user for possible changes. They act as 'adaptor' -- to changes. It's flexibility makes it a better option from the predictive planning.
Finally Use Case Diagrams. Use Case Diagrams define how your program will solve problems or provide some functionality.
Here's an example:
Use Case Diagrams usually deals with the interaction of Actors which could be a Human, or an External system. The Use cases are represented by the Elipses like "Insert Card".
The line from the actor towards the Use Cases are called communication lines.
The 'include' part means that two or more use case will try to access a single use case. whereas the 'extend' part is when a use case will try to access an optional use case.
The 'Select Amount' Use case is a general use case while under it are two specific use cases.
After this is the Use Case Description. Basically just a description of your use case. like " The user enters their card and inputs the pin. The system security will then check if the card is active or not stolen and/or if the inputted Pin is correct", etc. It will be wrapped up by saying that the system (security) will provide the funds and the receipt.
Another thing to note is the
Triggers (Machine receives the card/User enters Pin)
Actors
- Preconditions (e.g., bank has sufficient funds)
- Goals (e.g., Successful conclusions like being able to provide the user funds).
- List failed conclusion (ex: invalid card)
- Extensions (ex: If pin is invalid after three 3 tries)
- Steps of Execution (ex: From customer Inserts card up to the ejection of the card)
Activity Diagrams
Activity Diagrams basically just describes what actions occurred to achieve an ultimate goal. If you are familiar with flow charts, then it will be easier to understand the concepts behind Activity Diagrams.
Initial Nodes is the starting point of the Activity Diagram which is symbolize by a shaded circle.The purple colored notes simply describes the different components of an activity diagram.
Class Diagrams
Classes describes types of objects your program will use while Class Diagrams describe those classes and how they relate.
I will just upload some slide shows to make the tutorial faster:
Sequence Diagrams
Sequence diagrams model interactions in your program and provide you with a logical way to layout your system. They are about showing the order of interactions between the parts of your program.
In making sequence diagrams, you describe which interactions are triggered and when. They focus in on the order of events in all interactions.
Again, here are the sequence diagrams of the tutorial:
Communication Diagrams
Communication diagrams are used to show links between participants. They focus in on which interactions are triggered and when. They also describe the order of events in all interactions.
These ideas is from the video tutorials of Derek Banas
Here is a list of UML Tools. Some are free. :)
First You Should Understand What is UML and What is NOT
So start with reading Craig Larman's article What UML Is and Isn't
Then to Get an Idea How UML Can be Used "Wrong" Or How UML Should Not to be Used
Read the article Death by UML Fever by ALEX E. BELL. Pay attention to the industry experts(PHILIPPE KRUCHTEN,GRADY BOOCH) comments on that article.
Do not try to learn every detail of UML Notation
%20 of UML is enough for your %80 needs. Try not to use "less known" features.
You should not have to use all UML Diagrams. Use the one that you get benefit.
Best Modeling Tool
The Best Modeling tools are is free drawing places-surfaces like white boards, flip charts even papers. Not CASE tools.
Find a wall, and turn it to free drawing area with tools like Whiteboard-like Cling Sheets
Try Agile Modeling
Check side to get an Idea about Agile Modeling
Find A Good UML Book
To learn UML notation in short and brief way:
UML Distilled: A Brief Guide to the Standard Object Modeling Language (3rd Edition) by Martin Fowler
To Apply UML with a Process(RUP) in an Agile Way
Applying UML and Patterns: An Introduction to Object-Oriented Analysis and Design and Iterative Development (3rd Edition) by Craig Larman (Author)
For Short and Nice Guide with Guidelines
The Elements of UML(TM) 2.0 Style Scott W. Ambler (Author)
If You Not Like Books or Not Want to Spend Money
For Class Diagrams:
Check UML basics: The class diagram
For Sequence Diagrams
Check UML basics: The sequence diagram
For Activity Diagrams
Check UML basics: The activity diagram
Check UML 2 Activity Diagrams
For Use Case Diagrams
Check UML 2 Use Case Diagrams
Be carefull. Use cases are text stories which tell the interaction between user(actor) and system to achive a goal. So use case diagrams without use case texts are worthless.
To gain more understanding about use cases read the following free chapters from books:
- Larman-Chapter 6 Applying evolutionary use cases [ Free Download]
- Use case2.0 ebook Author: Ivar Jacobson, Ian Spence, Kurt Bittner. [Free Download]
For Sate Machine Diagrams
Check Sparx EA UML 2 State Machine Diagram
For the Component Diagrams
Check UML basics: The component diagram
For Deployment Diagrams
Check Sparx EA UML 2 Deployment Diagram
PS: There are other diagrams but those are most widely used ones.
AND Google it ...
For example I google it and see the http://www.uml-diagrams.org/uml-25-diagrams.html side.
It seems a good side for details.
This is how I learned a few of the terms when I was starting out. (I am still learning as well so if I am wrong please feel free to edit)
UML is just a way to describe how a system works using flowcharts. They have certain symbols to represent the different meanings.
Use case diagrams are just saying how something (They call it an actor) interacts with the system!
Activity diagram is kind of what it sounds like, the different activities that take place for a certain action to happen!
Here is an example: Activity Diagram for Banking System (UML)
There is still some I haven't answered, but the answers from the others are pretty good.