SlideShare uma empresa Scribd logo
Unified Modeling Language Maurício Edgar Stivanello
Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais;
Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais;
Evolução do software O surgimento de sistemas de software complexos resultou na necessidade de reavaliar a forma de desenvolver sistemas; As técnicas tem evoluído de forma impressionante, notavelmente no que tange à modelagem de sistemas.
Novos requisitos de sistemas Escalabilidade; Segurança; Robustez; De fácil manutenção; Reutilizável; Como resolver isso...
Modelagem Um modelo pode ser visto como uma representação idealizada de um sistema a ser construído; Maquetes de edifícios e de aviões e plantas de circuitos eletrônicos são apenas alguns exemplos de modelos; Uma simplificação da realidade que nos ajuda a entender um problema complexo;
Modelagem de software A modelagem de sistemas de software consiste na utilização de notações gráficas e textuais com o objetivo de construir modelos que representam as partes essenciais de um sistema, considerando-se diversas perspectivas diferentes e complementares.
Para que modelar Ajuda no gerenciamento da complexidade inerente ao desenvolvimento de software; Ajuda na comunicação entre as pessoas envolvidas; Ajuda na predição do comportamento futuro do sistema.
Evolução da modelagem Na primeira metade da década de 90 surgiram várias propostas de técnicas para modelagem de sistemas; Houve uma grande proliferação de propostas para modelagem de sistemas segundo o paradigma orientado a objetos; Existiam diferentes notações gráficas para modelar uma mesma perspectiva de um sistema.
Necessidade de um padrão Percebeu-se a necessidade de um padrão para a modelagem de sistemas, que fosse aceito e utilizado amplamente; Surgiram esforços nesse sentido de padronização, sendo o principal liderado por James Rumbaugh, Grady Booch e Ivar Jacobson (Rational).
Agenda Software e modelagem; UML Introdução ; Diagramas; Comentários finais;
UML... Surge a UML em 1996 como a melhor candidata para ser a linguagem unificadora de notações; Em 1997 a UML é aprovada como padrão pela OMG; Desde então tem tido  grande  aceitação; Atualmente na versão 2.0;
Características da UML É  uma linguagem visual; É  independente de linguagem de programação; É  independente de processo de desenvolvimento; Não  é uma linguagem de programação; Não  é uma metodologia.
Usos da UML Visualização; Especificação; Documentação; Comunicação; Construção.
Diagramas  Podem ser usados para... Mostrar os limites de um sistema e suas funções; Representa a estrutura estática de um sistema; Modelar o comportamento de objetos; Apresentar a implementação física e a arquitetura de um sistema;
Elementos Essenciais  Estruturais Classe Objeto Interface Nó Componente Relacionamentos
Elementos Essenciais  Comportamentais Caso de uso Ator Estados Mensagens
Elementos Essenciais  Extensão Notas Tagged Values
Elementos Essenciais  Agrupamento Pacotes
Agenda Software e modelagem; UML Introdução; Diagramas ; Comentários finais;
Diagrama de Casos de Uso Visão Geral Descreve o que o sistema faz do ponto de vista do observador externo; Ajuda a esclarecer os requisitos do sistema; Ajuda a dividir o desenvolvimento do sistema em tarefas;
Diagrama de Casos de Uso  Caso de uso Representa as diferentes funcionalidades que o sistema disponibiliza aos usuários.
Diagramas de Caso de Uso  Atores Diferentes usuários que operam o sistema; Sistemas externos que interagem com o sistema;
Diagramas de Caso de Uso  Associação Representa a comunicação entre o ator e o caso de uso; Também existem associações entre casos de usos;
Diagramas de Caso de Uso  Diagrama completo
Diagramas de Classe  Visão Geral Largamente utilizado; Descreve os diferentes tipos de objeto e o relacionamentos entre eles.
Diagramas de Classe  Classes Estereótipo; Atributos; Operações; Visibilidade; Tipo;
Diagramas de Classe  Relacionamentos Associações representam relações entre ocorrências de classes;
Diagramas de Classe  Relacionamentos Multiplicidade; Navegabilidade;
Diagramas de Classe  Relacionamentos Agregação; Composição;
Diagramas de Classe  Relacionamentos Generalização; Dependência;
Diagramas de Classe  Pacotes Agrupa classes relacionadas;
Diagramas de Classe  Diagrama completo
Diagrama de Seqüência  Mostra um conjunto de objetos, seus relacionamentos e as mensagens que podem ser enviadas entre eles; Diagrama de seqüência dá ênfase à seqüência de mensagens;
Diagrama de Seqüência  Objetos Representa uma instância de uma determinada classe;
Diagrama de Seqüência  Mensagens Representa troca de mensagens entre os objetos;
Diagrama de Seqüência  Fragmentos Servem para separar blocos de mensagens condicionadas a teste ou laço;
Diagrama de Seqüência
Diagrama de estados Exibe os possíveis estados de um objeto; Exibe também as transições que causam a mudança de estado.
Diagramas de Classe  Elementos básicos Estado inicial; Estado final; Estado intermediário;
Diagramas de Estados  Diagrama completo
Diagramas de Implantação  Visão Geral Mostra a configuração de software ou hardware; Permite avaliar as diferentes situações de implantação do sistema.
Diagramas de Implantação  Elementos básicos Componente; Nó.
Diagramas de Implantação  Diagrama completo
Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais ;
Design na metodologia hoje  Exemplo do RUP
Quanto esforço empregar Projeto; Equipe de trabalho; Complexidade; Automatismos possíveis;
Engenharia Reversa Útil quando se quer trabalhar com sistemas sem documentação; Nem sempre o resultado é satisfatório;
Ferramentas sugeridas StarUML em  www.staruml.com   Poseidon em  www.gentleware.com Umbrello em  http://uml.sourceforge.net/index.php Rational Rose em  www.rational.com Dentre outras...
Fontes OMG –  www.omg.org UML –  www.uml.org UML Essencial – Grady Booch, Ivar Jacobson e James Rumbaugh
Obrigado... [email_address]

Mais conteúdo relacionado

PPT
Apresentação da UML
PDF
Aula UML - Unified Modeling Language
PPT
UML - Criando Diagramas Eficientes
PPTX
Uml Diagramas Estruturais
PDF
Aula 7 - Modelagem de Software
PPTX
Arquitetura de Software EXPLICADA
ODP
Diagrama de Casos de Uso
Apresentação da UML
Aula UML - Unified Modeling Language
UML - Criando Diagramas Eficientes
Uml Diagramas Estruturais
Aula 7 - Modelagem de Software
Arquitetura de Software EXPLICADA
Diagrama de Casos de Uso

Mais procurados (20)

PPT
Aula de Analise e Projetos - Diagramas UML - prof. Rudson Kiyoshi S. Carvalho
PDF
Aula 1 - Introdução a Engenharia de Software
PDF
Introdução à linguagem UML
PDF
Desenvolvimento de Sistemas Web - Conceitos Básicos
PDF
Aula 1 - Introdução a POO
PPT
Análise Orientada a Objetos - Objetos E Classes
PPT
Introdução a analise de sistemas i
PPTX
Padrões MVC
PDF
Modelos de Engenharia de Software
PDF
Lógica de programação em ppt
PDF
Metodologia orientado a objetos
PPT
Aula1 e aula2 - Analise e Projeto de Sistemas
PPTX
Programação Orientado a Objetos
DOC
Aps lista de exercícios
PDF
Aula 1 - Revisão UML
PDF
Python - Programação funcional
POT
Algoritmo 06 - Array e Matrizes
ODP
Introdução à Análise de Sistemas
PPTX
Aula - Metodologias Ágeis
PDF
Arquitetura de Software Na Pratica
Aula de Analise e Projetos - Diagramas UML - prof. Rudson Kiyoshi S. Carvalho
Aula 1 - Introdução a Engenharia de Software
Introdução à linguagem UML
Desenvolvimento de Sistemas Web - Conceitos Básicos
Aula 1 - Introdução a POO
Análise Orientada a Objetos - Objetos E Classes
Introdução a analise de sistemas i
Padrões MVC
Modelos de Engenharia de Software
Lógica de programação em ppt
Metodologia orientado a objetos
Aula1 e aula2 - Analise e Projeto de Sistemas
Programação Orientado a Objetos
Aps lista de exercícios
Aula 1 - Revisão UML
Python - Programação funcional
Algoritmo 06 - Array e Matrizes
Introdução à Análise de Sistemas
Aula - Metodologias Ágeis
Arquitetura de Software Na Pratica
Anúncio

Destaque (20)

PPT
Uml diagramas implementacao_2008
PPT
Diagrama de implantação
PPTX
Principais diagramas da UML
PPT
Análise Orientada a Objetos - Diagrama de Sequencia
PDF
Articulo amcham pdf
PPT
Introdução à análise orientada a objetos parte 3
PPTX
07 Modelagem (Sommer)
PPT
Modelando Sistemas com UML
PPT
Mvc
PPT
Palestra introdução a uml e casos de uso final_parte1
PPT
Análise e Projeto de Sistemas com UML e Java
PDF
Primeira Aula PHP
PPT
Visibilidade e Diagrama de Classe de Projeto na UML
DOCX
Matemática – potência 01 2014
PDF
Modelos de comunicacão
PPTX
Unidades de Medida e Notação Científica
PPT
Estimativa de software usando pontos de função
PPTX
Propriedades da potenciação
PDF
Propriedades Da MultiplicaçãO De NúMeros Racionais
PDF
Modelagem Aplicações Web com UML
Uml diagramas implementacao_2008
Diagrama de implantação
Principais diagramas da UML
Análise Orientada a Objetos - Diagrama de Sequencia
Articulo amcham pdf
Introdução à análise orientada a objetos parte 3
07 Modelagem (Sommer)
Modelando Sistemas com UML
Mvc
Palestra introdução a uml e casos de uso final_parte1
Análise e Projeto de Sistemas com UML e Java
Primeira Aula PHP
Visibilidade e Diagrama de Classe de Projeto na UML
Matemática – potência 01 2014
Modelos de comunicacão
Unidades de Medida e Notação Científica
Estimativa de software usando pontos de função
Propriedades da potenciação
Propriedades Da MultiplicaçãO De NúMeros Racionais
Modelagem Aplicações Web com UML
Anúncio

Semelhante a Uml (20)

PPT
CursoUML - Unified Modeling Language
PDF
8-uml-e-modelagem-oo Introdução a UML.pdf
PPT
Unified Modeling Language
PPT
UML (1).ppt
ODP
A Linguagem UML
PPS
Modelagem 21102006_1
PDF
Aula 5 -_fundamentos_de_uml
PDF
PPTX
Aula 5 uml1 (1)
PDF
PDF
uml-intro_v02.pdf
PPTX
Trabalho uml
PDF
Apostila de uml
PPTX
UML - Historia e Diagrmas
DOC
Apostila uml
PPTX
Diagrama UML Pergamum
PDF
Apostila uml
PDF
Apostila UML
DOC
Apostila uml
CursoUML - Unified Modeling Language
8-uml-e-modelagem-oo Introdução a UML.pdf
Unified Modeling Language
UML (1).ppt
A Linguagem UML
Modelagem 21102006_1
Aula 5 -_fundamentos_de_uml
Aula 5 uml1 (1)
uml-intro_v02.pdf
Trabalho uml
Apostila de uml
UML - Historia e Diagrmas
Apostila uml
Diagrama UML Pergamum
Apostila uml
Apostila UML
Apostila uml

Último (20)

PDF
Custos e faturamento no SAP S/4HANA Transportation Management, S4TM3 Col26
PPTX
Curso de Java 17 - (JEE (Sessões e Cookies)).pptx
PDF
Otimizador de planejamento e execução no SAP Transportation Management, TM120...
PPTX
Émile Durkheim slide elaborado muito bom
PPTX
Curso de Java 14 - (Explicações Adicionais (Classes Abstrata e Interface)).pptx
PDF
Apple Pippin Uma breve introdução. - David Glotz
PPTX
Programação - Linguagem C - Variáveis, Palavras Reservadas, tipos de dados, c...
PPTX
Curso de Java 9 - (Threads) Multitarefas.pptx
PPTX
Curso de Java 16 - (JEE (Utilizando o Padrão MVC)).pptx
PPTX
Aula sobre banco de dados com firebase db
PPTX
Gestao-de-Bugs-em-Software-Introducao.pptxxxxxxxx
PDF
Fullfilment AI - Forum ecommerce 2025 // Distrito e Total Express
PDF
Processos na gestão de transportes, TM100 Col18
PPTX
Curso de Java 11 - (Serializable (Serialização de Objetos)).pptx
PPTX
BANCO DE DADOS - AULAS INICIAIS-sgbd.pptx
PDF
20250805_ServiceNow e a Arquitetura Orientada a Serviços (SOA) A Base para Ap...
PDF
COBITxITIL-Entenda as diferença em uso governança TI
PPTX
Curso de Java 13 - (JavaEE (JSP e Servlets)).pptx
PPTX
Curso de Java 10 - (IO Manipulação de Arquivos).pptx
PDF
Mergulho profundo técnico para gestão de transportes no SAP S/4HANA, S4TM6 Col14
Custos e faturamento no SAP S/4HANA Transportation Management, S4TM3 Col26
Curso de Java 17 - (JEE (Sessões e Cookies)).pptx
Otimizador de planejamento e execução no SAP Transportation Management, TM120...
Émile Durkheim slide elaborado muito bom
Curso de Java 14 - (Explicações Adicionais (Classes Abstrata e Interface)).pptx
Apple Pippin Uma breve introdução. - David Glotz
Programação - Linguagem C - Variáveis, Palavras Reservadas, tipos de dados, c...
Curso de Java 9 - (Threads) Multitarefas.pptx
Curso de Java 16 - (JEE (Utilizando o Padrão MVC)).pptx
Aula sobre banco de dados com firebase db
Gestao-de-Bugs-em-Software-Introducao.pptxxxxxxxx
Fullfilment AI - Forum ecommerce 2025 // Distrito e Total Express
Processos na gestão de transportes, TM100 Col18
Curso de Java 11 - (Serializable (Serialização de Objetos)).pptx
BANCO DE DADOS - AULAS INICIAIS-sgbd.pptx
20250805_ServiceNow e a Arquitetura Orientada a Serviços (SOA) A Base para Ap...
COBITxITIL-Entenda as diferença em uso governança TI
Curso de Java 13 - (JavaEE (JSP e Servlets)).pptx
Curso de Java 10 - (IO Manipulação de Arquivos).pptx
Mergulho profundo técnico para gestão de transportes no SAP S/4HANA, S4TM6 Col14

Uml

  • 1. Unified Modeling Language Maurício Edgar Stivanello
  • 2. Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais;
  • 3. Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais;
  • 4. Evolução do software O surgimento de sistemas de software complexos resultou na necessidade de reavaliar a forma de desenvolver sistemas; As técnicas tem evoluído de forma impressionante, notavelmente no que tange à modelagem de sistemas.
  • 5. Novos requisitos de sistemas Escalabilidade; Segurança; Robustez; De fácil manutenção; Reutilizável; Como resolver isso...
  • 6. Modelagem Um modelo pode ser visto como uma representação idealizada de um sistema a ser construído; Maquetes de edifícios e de aviões e plantas de circuitos eletrônicos são apenas alguns exemplos de modelos; Uma simplificação da realidade que nos ajuda a entender um problema complexo;
  • 7. Modelagem de software A modelagem de sistemas de software consiste na utilização de notações gráficas e textuais com o objetivo de construir modelos que representam as partes essenciais de um sistema, considerando-se diversas perspectivas diferentes e complementares.
  • 8. Para que modelar Ajuda no gerenciamento da complexidade inerente ao desenvolvimento de software; Ajuda na comunicação entre as pessoas envolvidas; Ajuda na predição do comportamento futuro do sistema.
  • 9. Evolução da modelagem Na primeira metade da década de 90 surgiram várias propostas de técnicas para modelagem de sistemas; Houve uma grande proliferação de propostas para modelagem de sistemas segundo o paradigma orientado a objetos; Existiam diferentes notações gráficas para modelar uma mesma perspectiva de um sistema.
  • 10. Necessidade de um padrão Percebeu-se a necessidade de um padrão para a modelagem de sistemas, que fosse aceito e utilizado amplamente; Surgiram esforços nesse sentido de padronização, sendo o principal liderado por James Rumbaugh, Grady Booch e Ivar Jacobson (Rational).
  • 11. Agenda Software e modelagem; UML Introdução ; Diagramas; Comentários finais;
  • 12. UML... Surge a UML em 1996 como a melhor candidata para ser a linguagem unificadora de notações; Em 1997 a UML é aprovada como padrão pela OMG; Desde então tem tido grande aceitação; Atualmente na versão 2.0;
  • 13. Características da UML É uma linguagem visual; É independente de linguagem de programação; É independente de processo de desenvolvimento; Não é uma linguagem de programação; Não é uma metodologia.
  • 14. Usos da UML Visualização; Especificação; Documentação; Comunicação; Construção.
  • 15. Diagramas Podem ser usados para... Mostrar os limites de um sistema e suas funções; Representa a estrutura estática de um sistema; Modelar o comportamento de objetos; Apresentar a implementação física e a arquitetura de um sistema;
  • 16. Elementos Essenciais Estruturais Classe Objeto Interface Nó Componente Relacionamentos
  • 17. Elementos Essenciais Comportamentais Caso de uso Ator Estados Mensagens
  • 18. Elementos Essenciais Extensão Notas Tagged Values
  • 19. Elementos Essenciais Agrupamento Pacotes
  • 20. Agenda Software e modelagem; UML Introdução; Diagramas ; Comentários finais;
  • 21. Diagrama de Casos de Uso Visão Geral Descreve o que o sistema faz do ponto de vista do observador externo; Ajuda a esclarecer os requisitos do sistema; Ajuda a dividir o desenvolvimento do sistema em tarefas;
  • 22. Diagrama de Casos de Uso Caso de uso Representa as diferentes funcionalidades que o sistema disponibiliza aos usuários.
  • 23. Diagramas de Caso de Uso Atores Diferentes usuários que operam o sistema; Sistemas externos que interagem com o sistema;
  • 24. Diagramas de Caso de Uso Associação Representa a comunicação entre o ator e o caso de uso; Também existem associações entre casos de usos;
  • 25. Diagramas de Caso de Uso Diagrama completo
  • 26. Diagramas de Classe Visão Geral Largamente utilizado; Descreve os diferentes tipos de objeto e o relacionamentos entre eles.
  • 27. Diagramas de Classe Classes Estereótipo; Atributos; Operações; Visibilidade; Tipo;
  • 28. Diagramas de Classe Relacionamentos Associações representam relações entre ocorrências de classes;
  • 29. Diagramas de Classe Relacionamentos Multiplicidade; Navegabilidade;
  • 30. Diagramas de Classe Relacionamentos Agregação; Composição;
  • 31. Diagramas de Classe Relacionamentos Generalização; Dependência;
  • 32. Diagramas de Classe Pacotes Agrupa classes relacionadas;
  • 33. Diagramas de Classe Diagrama completo
  • 34. Diagrama de Seqüência Mostra um conjunto de objetos, seus relacionamentos e as mensagens que podem ser enviadas entre eles; Diagrama de seqüência dá ênfase à seqüência de mensagens;
  • 35. Diagrama de Seqüência Objetos Representa uma instância de uma determinada classe;
  • 36. Diagrama de Seqüência Mensagens Representa troca de mensagens entre os objetos;
  • 37. Diagrama de Seqüência Fragmentos Servem para separar blocos de mensagens condicionadas a teste ou laço;
  • 39. Diagrama de estados Exibe os possíveis estados de um objeto; Exibe também as transições que causam a mudança de estado.
  • 40. Diagramas de Classe Elementos básicos Estado inicial; Estado final; Estado intermediário;
  • 41. Diagramas de Estados Diagrama completo
  • 42. Diagramas de Implantação Visão Geral Mostra a configuração de software ou hardware; Permite avaliar as diferentes situações de implantação do sistema.
  • 43. Diagramas de Implantação Elementos básicos Componente; Nó.
  • 44. Diagramas de Implantação Diagrama completo
  • 45. Agenda Software e modelagem; UML Introdução; Diagramas; Comentários finais ;
  • 46. Design na metodologia hoje Exemplo do RUP
  • 47. Quanto esforço empregar Projeto; Equipe de trabalho; Complexidade; Automatismos possíveis;
  • 48. Engenharia Reversa Útil quando se quer trabalhar com sistemas sem documentação; Nem sempre o resultado é satisfatório;
  • 49. Ferramentas sugeridas StarUML em www.staruml.com Poseidon em www.gentleware.com Umbrello em http://uml.sourceforge.net/index.php Rational Rose em www.rational.com Dentre outras...
  • 50. Fontes OMG – www.omg.org UML – www.uml.org UML Essencial – Grady Booch, Ivar Jacobson e James Rumbaugh

Notas do Editor

  • #2: Large enterprise applications - the ones that execute core business applications, and keep a company going - must be more than just a bunch of code modules. They must be structured in a way that enables scalability, security, and robust execution under stressful conditions, and their structure - frequently referred to as their architecture - must be defined clearly enough that maintenance programmers can (quickly!) find and fix a bug that shows up long after the original authors have moved on to other projects. That is, these programs must be designed to work perfectly in many areas, and business functionality is not the only one (although it certainly is the essential core). Of course a well-designed architecture benefits any program, and not just the largest ones as we've singled out here. We mentioned large applications first because structure is a way of dealing with complexity, so the benefits of structure (and of modeling and design, as we'll demonstrate) compound as application size grows large. Another benefit of structure is that it enables code reuse : Design time is the easiest time to structure an application as a collection of self-contained modules or components. Eventually, enterprises build up a library of models of components, each one representing an implementation stored in a library of code modules. When another application needs the same functionality, the designer can quickly import its module from the library. At coding time, the developer can just as quickly import the code module into the application.  
  • #6: Não é possível avaliar tudo isso na implementação. O momento ideal é no projeto do software.
  • #7: Modeling is the designing of software applications before coding. Modeling is an Essential Part of large software projects, and helpful to medium and even small projects as well. A model plays the analogous role in software development that blueprints and other plans (site maps, elevations, physical models) play in the building of a skyscraper. Using a model, those responsible for a software development project's success can assure themselves that business functionality is complete and correct, end-user needs are met, and program design supports requirements for scalability, robustness, security, extendibility, and other characteristics, before implementation in code renders changes difficult and expensive to make. Surveys show that large software projects have a huge probability of failure - in fact, it's more likely that a large software application will fail to meet all of its requirements on time and on budget than that it will succeed. If you're running one of these projects, you need to do all you can to increase the odds for success, and modeling is the only way to visualize your design and check it against requirements before your crew starts to code.
  • #9: Modelos ajuda a pessoas iniciantes a se interarem do projeto mais rapidamente; Melhor errar no modelo; Modelar reduz a necessidade de retrabalho;
  • #10: Cada notação gráfica possuía suas vantagens e desvantagens;
  • #13: Ver versão; Em aperfeiçoamento questões como programação concorrente, etc.
  • #14: The OMG's Unified Modeling Language™ ( UML® ) helps you specify, visualize, and document models of software systems, including their structure and design, in a way that meets all of these requirements. (You can use UML for business modeling and modeling of other non-software systems too.) Using any one of the large number of UML-based tools on the market , you can analyze your future application's requirements and design a solution that meets them, representing the results using UML 2.0's thirteen standard diagram types .  You can model just about any type of application, running on any type and combination of hardware, operating system, programming language, and network, in UML. Its flexibility lets you model distributed applications that use just about any middleware on the market. Built upon  fundamental OO concepts including class and operation , it's a natural fit for object-oriented languages and environments such as C++, Java, and the recent C#, but you can use it to model non-OO applications as well in, for example, Fortran, VB, or COBOL.  UML Profiles (that is, subsets of UML tailored for specific purposes) help you model Transactional, Real-time, and Fault-Tolerant systems in a natural way.  You can do other useful things with UML too: For example, some tools analyze existing source code (or, some claim, object code!) and reverse-engineer it into a set of UML diagrams. Another example: Some tools on the market execute UML models, typically in one of two ways: Some tools execute your model interpretively in a way that lets you confirm that it really does what you want, but without the scalability and speed that you'll need in your deployed application. Other tools (typically designed to work only within a restricted application domain such as telecommunications or finance) generate program language code from UML, producing most of a bug-free, deployable application that runs quickly if the code generator incorporates best-practice scalable patterns for, e.g., transactional database operations or other common program tasks. (OMG members are working on a specification for Executable UML now.) Our final entry in this category: A number of tools on the market generate Test and Verification Suites from UML models. 
  • #16: What can you Model with UML? UML 2.0 defines thirteen types of diagrams, divided into three categories: Six diagram types represent static application structure; three represent general types of behavior; and four represent different aspects of interactions: Structure Diagrams include the Class Diagram, Object Diagram, Component Diagram, Composite Structure Diagram, Package Diagram, and Deployment Diagram.  Behavior Diagrams include the Use Case Diagram (used by some methodologies during requirements gathering); Activity Diagram, and State Machine Diagram.  Interaction Diagrams, all derived from the more general Behavior Diagram, include the Sequence Diagram, Communication Diagram, Timing Diagram, and Interaction Overview Diagram.
  • #22: Documenta as funcionalidades básicas do sistema, do ponto de vista do usuário; Ajudam a compreender os requisitos; Guiam o desenvolvimento do sistema, e muitas vezes são utilizados para dividir o desenvolvimento de sistemas em tarefas; Muitas vezes os requisitos levantados juntamente com os clientes são mapeados em use cases.
  • #24: Além de pessoas, também sistemas externos são representados por atores. Por exemplo, se você estiver desenvolvendo um sistema de automação para uma máquina da produção, que irá trocar informações com o sistema de estoque da indústria, este é representado nos diagramas por um ator.
  • #29: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #30: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #31: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #32: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #33: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #34: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #41: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #44: Relaciona classes que precisam conhecer uma a outra para realizar o seu trabalho;
  • #48: Certos projetos permitem automatismos sobre os modelos, de maneira a gerar código ou base de dados;
  • #50: 2) Select a UML Development Tool: Because most (although not all) UML-based tools implement a particular methodology, in some cases it might not be practical to pick a tool and then try to use it with a methodology that it wasn't built for. (For other tool/methodology combinations, this might not be an issue, or might be easy to work around.) But, some methodologies have been implemented on multiple tools so this is not strictly a one-choice environment.  You may find a tool so well-suited to your application or organization that you're willing to switch methodologies in order to use it. If that's the case, go ahead - our advice to pick a methodology first is general, and may not apply to a specific project. Another possibility: You may find a methodology that you like, which isn't implemented in a tool that fits your project size, or your budget, so you have to switch. If either of these cases happens to you, try to pick an alternative methodology that doesn't differ too much from the one you preferred originally.  As with methodologies, OMG doesn't have an opinion or rating of UML-based modeling tools, but we do have links to a number of lists here . These will help you get started making your choice.