Padrões de Software (Software Patterns)

Documentos relacionados
Padrões de Software (Software Patterns)

Curso - Padrões de Projeto Módulo 1: Introdução

Tópicos Avançados em Engenharia de Software

Padrões de Projeto. Prof. Jefersson Alex dos Santos

Programação Orientada a Objetos. Padrões de Criação

Padrões de Projeto de Software Orientado a Objetos

Prof.ª Esp. Talita Pagani

1Introdução Helder da Rocha

J930. Padrões. Projeto. Introdução. argonavis.com.br. Helder da Rocha

Padrões GoF. Leonardo Gresta Paulino Murta

Programação Avançada. Padrões de Projeto de Software. Fonte: Oswaldo B. Peres e K19 Treinamentos

Padrões de projeto 1

Padrões de Projeto WEB e o MVC

Design Patterns. Viviane Torres da Silva

Testes com Design Patterns

Análise e Projeto de Software

PADRÕES DE SOFTWARE. Jerffeson Teixeira de Souza, Ph.D. Tarciane de Castro Andrade. Grupo de Padrões de Software da UECE (GPS.

PADRÕES DE PROJETO E FRAMEWORK NO DESENVOLVIMENTO DE SOFTWARE

Padrões de Desenho (Design Patterns)

Casos de uso Objetivo:

2 Engenharia de Software

Uma Noção Intuitiva dos Padrões de Desenho de Software

Autoria:Aristófanes Corrêa Silva Adaptação: Alexandre César M de Oliveira

Engenharia de Software e Gerência de Projetos Prof. Esp. André Luís Belini Bacharel em Sistemas de Informações MBA em Gestão Estratégica de Negócios

Capítulo 2. Processos de Software Pearson Prentice Hall. Todos os direitos reservados. slide 1

Metadados. 1. Introdução. 2. O que são Metadados? 3. O Valor dos Metadados

UNIVERSIDADE FEDERAL RURAL DE PERNAMBUCO DEPARTAMENTO DE ESTATÍSTICA E INFORMÁTICA BACHARELADO EM SISTEMAS DE INFORMAÇÃO RAPID APPLICATION DEVELOPMENT

Guia de utilização da notação BPMN

Unidade 8: Padrão MVC e DAO Prof. Daniel Caetano

3.1 Definições Uma classe é a descrição de um tipo de objeto.

3. Fase de Planejamento dos Ciclos de Construção do Software

INF011 Padrões de Projeto. 02 Creational Patterns

3 Qualidade de Software

SISTEMAS DE INFORMAÇÃO GERENCIAIS

DESENVOLVENDO O SISTEMA

ESTENDENDO A UML PARA REPRESENTAR RESTRIÇÕES DE INTEGRIDADE

c. Técnica de Estrutura de Controle Teste do Caminho Básico

Padrões. Projeto (Design) de Software

Mas o que é mesmo Padrão de Projeto?

Resolução da lista de exercícios de casos de uso

Conteúdo. Disciplina: INF Engenharia de Software. Monalessa Perini Barcellos. Centro Tecnológico. Universidade Federal do Espírito Santo

Análise e Projeto Orientados por Objetos

SOFTWARE PATTERNS: FUNDAMENTOS, TIPOS E DESCRIÇÃO Sérgio Teixeira de Carvalho

UML & Padrões Aula 3. UML e Padrões - Profª Kelly Christine C. Silva

TÉCNICAS DE PROGRAMAÇÃO

Agenda Semântica. Grupo: Francisco Rodrigues Júnior Guilherme Daher Ferreira Luana Vieira Morellato Renan Rigo

Aula 2 Revisão 1. Ciclo de Vida. Processo de Desenvolvimento de SW. Processo de Desenvolvimento de SW. Processo de Desenvolvimento de SW

Padrões clássicos ou padrões GoF O livro "Design Patterns (1994) de Erich Gamma, John Vlissides, Ralph Jonhson e Richard Helm, descreve 23 padrões de

A ESTRUTURA DA GESTÃO DE

UNIVERSIDADE FEDERAL DE SANTA MARIA CENTRO DE TECNOLOGIA AULA 14 PROFª BRUNO CALEGARO

Processos de gerenciamento de projetos em um projeto

Arquivo original em Inglês: Management/Documents/Risk-IT-Brochure.pdf

Prototype, um Design Patterns de Criação

Separação de Interesses Programação Estruturada e Programação Orientada a Objetos Entrelaçamento de Código Espalhamento de Código

build UNIP Sistemas de Informação Análise Essencial de Sistemas 3 Prof.Marcelo Nogueira A produção de Software é uma atividade build and fix.

CONSTRUÇÃO DE UM FRAMEWORK PARA O DESENVOLVIMENTO DE APLICAÇÕES WEB

Argo Navis J931 - Padrões de Design J2EE. Introdução. Objetivos de aprender padrões J2EE. Conhecer padrões para uso na plataforma J2EE

Programação Orientada a Objetos. Introdução à Análise Orientada a Objetos (AOO)

Feature-Driven Development

Micro Mídia Informática Fevereiro/2009

UNEMAT SISTEMA DE INFORMAÇÃO (SI) Professora: Priscila Pelegrini

Classificação de Sistemas: Sistemas Empresariais

1 Introdução. Componentes Usuários. Provedor de Serviços. Figura 1.1 Ambiente de oferecimento de serviços

Planejamento - 7. Planejamento do Gerenciamento do Risco Identificação dos riscos. Mauricio Lyra, PMP

Roteiro SENAC. Análise de Riscos. Planejamento do Gerenciamento de Riscos. Planejamento do Gerenciamento de Riscos

O Processo de Engenharia de Requisitos

18º Congresso de Iniciação Científica IMPLEMENTAÇÃO DE UM MODELO DE TESTE DE APLICAÇÕES WEB

O Processo Unificado

Engenharia de Software II

UML - Unified Modeling Language

Pasteur Ottoni de Miranda Junior. Alguns Padrões de Projeto Gamma

Definição de Padrões. Padrões Arquiteturais. Padrões Arquiteturais. Arquiteturas de Referência. Da arquitetura a implementação. Elementos de um Padrão

Perguntas. Que todo usuário deveria fazer antes de comprar um software CAD de baixo custo. Por Robert Green, proprietário da Robert Green Consulting

Curso: Engenharia de Software com Ênfase em Padrões de Software (UECE Universidade Estadual do Ceará) RUP

O que é a UML? Introdução a UML. Objetivos da Modelagem. Modelos. A UML não é. Princípios da Modelagem. O que é um modelo?

Roteiro. Interfaces de Programação de Aplicações (Application Programming Interfaces) Conceitos BásicosB. ! Definição

MAPEAMENTO OBJETO RELACIONAL: UM ESTUDO DE CASO

Padrões de Interação com o Usuário

CURSO DE TECNOLOGIA EM ANÁLISE E DESENVOLVIMENTO DE SISTEMAS

ESTUDO DE CASO: LeCS: Ensino a Distância

Diagramas de Casos de Uso

ADMINISTRAÇÃO I. Família Pai, mãe, filhos. Criar condições para a perpetuação da espécie

Levantamento, Análise e Gestão Requisitos. Aula 06

A SEGUIR ALGUMAS DICAS PARA O DESENVOLVIMENTO DE UM PROJETO CIENTÍFICO

PRODUTO 1 (CONSTRUÇÃO DE PORTAL WEB)

A construção de um manual sobre a utilização dos modelos também poderá alavancar o uso das representações. Este conteria a explicação detalhada da

Análise e Desenvolvimento de Sistemas ADS Programação Orientada a Obejeto POO 3º Semestre AULA 03 - INTRODUÇÃO À PROGRAMAÇÃO ORIENTADA A OBJETO (POO)

Transcrição:

Padrões de Software (Software Patterns) Cleidson de Souza - cdesouza@ufpa.br Departamento de Informática Universidade Federal do Pará Agenda! Definição! Histórico! Considerações! Forma de um Padrão! Exemplo! Vantagens! Categorias de Padrões! O Catálogo de Gamma! Exemplos Padrão de Gabriel Idioma de Pree Padrões e Estratégias de Coad O Padrão de Projeto State de Gamma O padrão MVC! Anti-padrões! Referências Definição Definição(2)! Padrões (...) são um modo de capturar experiências ( ) de modo que outras pessoas possam utilizá-las[gamma93].! Padrões de projeto constituem um conjunto de regras descrevendo como realizar determinadas tarefas no desenvolvimento de software[pree94].! Apesar das diferentes definições, existe um consenso de que padrões são, uma parcela de experiência destilada, descrita como uma solução para um problema em uma dada situação[cam96].

Histórico! Este termo surgiu na década de 70 através do arquiteto Christopher Alexander, que encontrou temas recorrentes na arquitetura e os capturou em descrições e instruções que ele chamou de padrões.! Cada padrão descreve um problema que ocorre repetidamente em um ambiente, ele descreve o núcleo da solução do problema, de modo que você pode usar esta solução inúmeras vezes. Histórico(2)! Durante a década de 90, os projetistas de software descobriram a idéia de Alexander e tem aplicado-a no desenvolvimento de software.! Padrões de projeto são um meio para representar, registrar e reutilizar microarquiteturas de projeto repetitivas, bem como a experiência acumulada por projetistas durante o desenvolvimento de software. Histórico(3)! Atualmente, ele tem sido amplamente utilizado em todas as fases do desenvolvimento de software: desde a análise até a implementação. Padrões de análise; Padrões de projeto; Padrões de implementação - idiomas; Padrões para hipertexto; Padrões para colaboração - CSCW; Etc. Histórico Detalhado! 87, Cunningham e Beck: padrões (patterns) para Smalltalk! 91, Jim Coplien: Livro com Idiomas para C++! 91, Bruce Andersen OOPSLA workshop! 93, GoF: Livro sobre Padrões para Design! 94: Primeira Conferência de Padrões PLoP! 94 em diante: Padrões por toda parte!!!

Considerações Apesar de todos os avanços na tecnologia de software, ou mesmo por causa destes avanços, um problema básico ainda existe: a comunicação entre pessoas sobre as melhores práticas e soluções em Engenharia de Software Considerações (2)! O conhecimento de projetistas experientes É intangível e muito valioso Principal Fator para:! Sucesso: Gerentes e Técnicos Experientes! Fracasso: Gerentes e Técnicos Inexperientes Adquirido lentamente, trabalho duro e persistente Capturar, comunicar e assimilar elementos deste conhecimento é difícil Observações! Padrões complementam as abordagens correntes. Ou seja, eles podem ser utilizados em conjunto com metodologias de desenvolvimento de SW.! Existem padrões para cada uma das fases do desenvolvimento: análise, projeto, implementação, testes, etc.! Padrões são identificados e não inventados. Observações! Não é apenas para Orientação à Objetos. Por exemplo, podem existir padrões para análise estruturada, etc. De fato, existem padrões sobre como organizar uma empresa de desenvolvimento de SW, etc.! Utiliza alguns pressupostos básicos, opostos aos das abordagens tradicionais: é considerada uma abordagem humanística.

Exemplo: Padrão MVC! O padrão MVC (Model-View-Controller) é um padrão de arquitetura, ou seja, ele indica como deve ser a organização global do sistema.! Ele sugere a separação entre o modelo, a visão e o controle de uma aplicação: O modelo corresponde às classes do domínio da aplicação. A visão corresponde às classes de interface gráfica da aplicação. Finalmente, o controle corresponde as classes que conectam o modelo à visão. Exemplo: Padrão MVC! O padrão indica que as classes do modelo não devem conhecer as classes da visão. Isto diminui o acoplamento entre estes componentes, implicando que podemos mudar a interface do sistema (de gráfica para textual, por exemplo) sem afetar as classes do modelo.! De maneira análoga, as classes da UI não devem implementar regras de negócio. Exemplo: Padrão MVC! As classes de controle são o mecanismo que integra as classes da UI com as classes do modelo. Elas encapsulam como os objetos interagem promovendo um baixo acoplamento entre elas e permitindo que suas implementações possam ser modificadas independentemente. Exemplo: Padrão MVC! As classes de controle contém tipicamente informação de sequenciamento das operações. Deve-se tomar cuidado, pois as classes de controle NÃO DEVEM executar tarefas que tipicamente pertençam às outras classes.

Vantagens dos Padrões! Constituem uma base de experiência reutilizável para a construção de software. Eles fornecem um modo de reutilizar o conhecimento (expertise) de projetistas experientes, e com isso facilitam o treinamento de novos desenvolvedores;! Os padrões de projeto formam um vocabulário comum para os projetistas se comunicarem e para a documentação e exploração das alternativas de projeto; Vantagens dos Padrões (2)! Atuam como "blocos de construção" que podem ser utilizados para criar aplicações mais complexas;! Reduzem o tempo de aprendizado de bibliotecas de classes e frameworks. Uma vez que um usuário tenha aprendido uma biblioteca, ele pode reutilizar esta experiência para aprender novas bibliotecas; Vantagens dos Padrões (3)! Permitem larga reutilização de arquiteturas de software, mesmo que a reutilização de algoritmos, implementações, interfaces ou projetos detalhados não seja permitida;! Reduzem a complexidade do sistema, pois nomeiam e identificam abstrações que estão em um nível de abstração acima das classes e instâncias; Forma de um Padrão! Um padrão apresente quatro elementos essenciais: O Nome do padrão; O Problema; Solução; e Conseqüências

Forma: Nome do padrão! É usado para descrever um problema, sua solução e suas conseqüências. Deste modo, o vocabulário dos projetistas é ampliado, facilitando o desenvolvimento de software, uma vez que existirá um vocabulário comum que permitirá a troca de experiência entre projetistas através da comunicação das decisões de projeto, e facilitará a documentação do sistema. Forma: O Problema! Descreve quando aplicar o padrão. Explica o problema em questão e o contexto. Pode descrever problemas específicos ou genéricos. Normalmente, pelo menos dois exemplos são apresentados para cada padrão. Forma: Solução! Descreve os elementos que formam o padrão, seus relacionamentos, responsabilidades e documentação. A solução é apresentada para um problema genérico e uma estrutura geral.! Dependendo da categoria do padrão, a solução é apresentada de maneira diferente. Forma: Conseqüências! São os resultados e decisões que a utilização daquele padrão acarretam. A descrição destas conseqüências é vital para uma avaliação dos custos e benefícios de um padrão e, consequentemente, para auxiliar a decisão sobre sua utilização. As conseqüências de um padrão incluem, por exemplo, seu impacto sobre a flexibilidade, portabilidade e expansibilidade do sistema.

Categorias de Padrões! Padrões de projeto possuem diferentes níveis de abstração e podem auxiliar em todas as fases do ciclo de vida de desenvolvimento. Segundo Buschmann [, 1996], os padrões podem ser agrupados em três categorias, a saber: Padrões de Arquitetura; Padrões de Análise e Projeto; e Idiomas Padrões de Arquitetura:! Expressam um esquema da organização global da estrutura do sistema. Eles provêem um conjunto de subsistemas prédefinidos, especificando os relacionamentos entre eles e estabelecendo regras para esses relacionamentos.! Exemplo: Reflexão, MVC (Model-View- Controller). Padrões de Análise e Projeto! Fornecem um esquema para refinar os subsistemas ou componentes do sistema de software.! Esses padrões possuem um grau de granularidade considerado médio e são independentes de linguagem de programação. Padrões de projeto, geralmente, correspondem a uma abstração de duas, três ou um pequeno número de classes. Padrões de Análise e Projeto! Os padrões de projeto mais famosos são os padrões de Erich Gamma, Richard Helm, Ralph Johnson, e John Vlissides. Estes autores ficaram conhecidos como Gang of Four (GoF). Estes padrões correspondem ao chamado catálogo de padrões. Exemplo: Strategy, State, etc.! Os padrões de Coad são famosos padrões de análise.

Idiomas! São os padrões de nível mais baixo, específicos para um determinada linguagem de programação.! Eles descrevem como implementar aspectos particulares de componentes e dos relacionamentos entre eles usando características específicas da linguagem alvo. Idiomas! Além disso, formam uma base para a padronização da nomenclatura e da estrutura do código fonte. Sob este ponto de vista, eles agem como diretrizes de projeto ou, ainda, como convenções para o modo de atribuir nomes. Categorias de Padrões! Além desta classificação, os padrões podem ser classificados segundo o domínio no qual se aplicam. Assim, podem existir padrões genéricos, que podem ser aplicados em diferentes domínios; Mas também podem existir padrões específicos para determinados domínios como por exemplo, tolerância a falhas, criptografia, telecomunicações, etc. Exemplos de Padrões! Software Orientado a Objetos (GoF)! Organizações e Processos (James Coplien)! Arquitetura de Software (Mary Shaw; e Frank Buschmann et. al.)! Programação em Smalltalk (Kent Back)! Integridade de Informações; (Ward Cunningham)! Programação em Java (Doug Lea)

Exemplos de Padrões(cont cont.)! Patterns para (Análise) Orientação a Objetos (Peter Coad)! Introdução de Novas Tecnologias em Organizações (Linda Rising e outros)! Alexander e Qualidade de Software (Richard Gabriel)! Patterns para Software para Comunicação em Redes (Douglas Schmidt) O Catálogo de Gamma Design Patterns: Elements of Reusable Object- Oriented Software por Erich Gamma, Richard Helm, Ralph Johnson, e John Vlissides. Addison Wesley 1994. O Catálogo de Gamma! O catálogo de Gamma é o exemplo mais famoso de padrões de projeto. A partir deste livro, diversos outros trabalhos foram publicados. Este catálogo contém 23 padrões.! Ele baseia-se na experiência obtida pelos autores com diversos frameworks, no quais estruturas de projeto elegantes, flexíveis e bem-estruturadas foram identificadas. Forma dos Padrões no Catálogo! Nome do Padrão e Classificação: o nome do padrão e sua classificação são apresentados.! Intenção: esta seção deve responder às seguintes questões: O que o padrão faz? Qual sua razão e sua intenção? Que características particulares do problema o padrão resolve?! Também conhecido como: outros nomes conhecidos para o padrão.

Forma dos Padrões no Catálogo! Motivação: descreve um cenário com um problema prático onde o padrão é utilizado para resolver o problema.! Aplicabilidade: esta seção deve responder à seguinte questão: em que situação o padrão pode ser aplicado?! Estrutura: descreve a representação gráfica das classes do padrão através de uma notação baseada na OMT, além de diagramas de interação. Forma dos Padrões no Catálogo! Participantes: descreve as classes e objetos que participam do padrão, além de suas responsabilidades.! Colaborações: descreve como os participantes colaboram para atingir as suas responsabilidades.! Conseqüências: apresenta os resultados e decisões que devem ser tomadas para a implementação do padrão de projeto. Forma dos Padrões no Catálogo! Trechos de Código: fragmentos de código C++ ou Smalltalk que ilustram como o padrão pode ser implementado.! Usos Conhecidos: exemplos do padrão encontrados em sistemas reais. No mínimo dois exemplos de diferentes domínio são apresentados.! Padrões Relacionados: descreve outros padrões relacionados que podem substituir ou complementar o padrão que está sendo descrito. Classificação dos Padrões Escopo vs. Propósito Criação Estrutura Comportamento Classe Factory Method Adapter (classe) Interpreter Template Method Objeto Abstract Factory Builder Prototype Singleton Adapter (objeto) Bridge Composite Decorator Facade Flyweight Proxy Chain of Responsibility Command Iterator Mediator Memento Observer State Strategy Visitor

Anti-Padrões! Os padrões indicam boas estruturas de análise, projeto ou implementação no desenvolvimento de software. Os anti-padrões indicam exatamente o contrário.! O foco dos anti-padrões são os erros comuns dos projetistas e as principais falhas que levam ao fracasso no desenvolvimento de software.! Livros sobre anti-padrões apresentam também dicas práticas em como detectá-los e como reorganizar o sistema de modo a corrigi-los. Conclusões! Como ser um bom jogador de xadrez? Primeiro, aprende-se as regras. Depois, estuda-se os exemplos de bons jogadores.! Os padrões de software implementam a mesma idéia para desenvolvimento de software. Desta forma, são uma abordagem bastante promissora para o desenvolvimento de software. Referências: Livros! Livros do Christopher Alexander! Gamma et al. Design Patterns:..., 1994.! Coplien&Schmidt (eds.) Pattern Languages of Program Design Addison-Wesley, 1995.! Buschmann et al. Pattern-Oriented Software Architecture, Wiley, 1996. Referências: Internet e Conferências! http://st.www.cs.uiuc.edu/users/patterns/p atterns.html! PLoP: Conferência, EUA.! EuroPLoP: Conferência, Europa.! OOPSLA: Sobre Orientação a Objetos, EUA.

Referências: Colunas de Revistas!J. Coplien, The Colunm Without a Name, C++ Report, 94+! R. Gabriel, Critic-at-Large, JOOP, 93-94! Vlissides, Pattern Hatching,C++ Report,95+! Johnson, Patterns of Thought, ROAD, 94+ Outras Referências! Lea, D. Christopher Alexander: An Introduction for Object-Oriented Designers, SEN, 19(1), 1994! Brad Appleton, Patterns and Software: Essential Concepts and Terminology, http:// www. enteract. com/ ~bradapp/ docs/ patternsintro.html! IEEE Software, janeiro/fevereiro 1997: Object Methods, Patterns, and Architectures Coplien: Idioms and Patterns as Architectural Literature Kerth and Cunningham: Using Patterns to Improve our Architectural Vision Times! Análise e Interfaces 1. alline lemos 2. alline peixoto 3. Flavia 4. leandro 5. luiz otavio 6. paula danielle 7. Priscila 8. Jose Enderson 9. Reinaldo! Arquitetos adailton anderson marcelo marcio braga rafael weverton! Implementação 1. Cleberson 2. Dedier 3. Diego 4. Ernani Sales 5. Fabio Borges 6. Leonardo 7. Marcio Kuroki 8. Marlos 9. Tacio! Teste 1. Adriano 2. aline patricia 3. Amanda 4. billy 5. breno 6. franklin harrison 7. joseane 8. luiz alberto 9. pedro leandro Observações! Contato: email: odiney@cei.ssp ssp.pa.gov..gov.br telefone no cei: : 3259 0555 / 3259 0599 Apresentação: 2 de Fevereiro Entrega: 7 de Fevereiro! Segunda Chamada 31 de Janeiro Substituição de notas. Assunto: orientação a objetos + assuntos vistos em sala.

Exemplos de Padrões Richard Gabriel: Simply Understood Code! Exemplo de um padrão bom e humanístico. Intuitivo, mas muito ignorado.!... arrange the importante parts of the code so it fits on one page. Make that code understandable to a person reading it from top to bottom. Do not require the code to be repeatedly scanned in order to understand how data is used and how control moves about... Exemplo: o idioma de Pree! Pree apresenta uma outra abordagem que se refere a convenções de nomes a serem dados a variáveis, constantes e métodos. O trabalho de Pree é baseado nas convenções descritas no framework ET++.! A utilização de convenções de nomenclatura em frameworks é importante, pois facilita o aprendizado e utilização do mesmo. Exemplo: o idioma de Pree! Nomes de classes e de métodos: devem iniciar com letras maiúsculas seguidos de letras minúsculas.! Variáveis locais devem iniciar com letras minúsculas.! Se um nome consiste de várias palavras, a segunda e as palavras subsequentes iniciam com letras maiúsculas, como por exemplo DoLeftButtonDownCommand(...).! Variáveis globais: devem iniciar com o prefixo g, como: gfiledialog, gapplication.

Exemplo: o idioma de Pree! Constantes: devem iniciar com o prefixo c, como: cldnone.! Métodos: quando definem o valor de uma variável instanciada devem iniciar com Set, como em SetSaldo(..). Métodos que retornam tais valores devem iniciar com Get, como GetOrigin(...).! Métodos que desenham objetos na tela devem iniciar com Gr, como GrPaintRect().! Etc... Exemplo: A abordagem de Coad! A abordagem de Coad para padrões de software divide-se na apresentação de estratégias e de padrões propriamente ditos.! Coad apresenta 177 estratégias e 31 padrões, que são mais adequados a fase de análise. Entretanto, Coad não faz nenhuma distinção sobre quando os padrões podem ser aplicados. Exemplo: A abordagem de Coad! Uma estratégia é um plano de ação que deve ser utilizado para alcançar determinados objetivos durante a realização das atividades de construção do modelo de objetos.! Um padrão é um bloco de construção útil para o desenvolvimento de software orientado a objetos. Exemplo: A abordagem de Coad! As estratégias estão divididas em 6 categorias, a saber: Atividades e Componentes do Modelo Identificar o propósito e características do sistema Selecionar objetos Estabelecer Responsabilidades Construir cenários Descobrir novas estratégias e padrões

Exemplo: A abordagem de Coad! Exemplo de uma Estratégia para Identificação de Objetos. Estratégia Número 13: Selecionar Atores. Exemplo: A abordagem de Coad! Exemplo de Padrão: Transação - Item de Transação! Procurar por atores, que são pessoas e organizações que atuam como participantes no sistema em construção.! Exemplos: pessoa, organização (agência, companhia, corporação, fundação, etc.). Exemplo: Padrão State! O padrão de projeto State apresenta uma solução genérica para o problema de modelagem de objetos que apresentam diferentes estados ``lógicos' e também comportamentos variados dependendo do estado lógico corrente. Exemplo: Padrão State! O padrão define uma hierarquia de estados paralela à hierarquia de classes e o objeto da aplicação delega as operações dependentes de estado para um objeto representando o seu estado corrente. Em tempo de execução o objeto da aplicação pode mudar seu estado lógico, implicando também numa alteração em seu comportamento.

Exemplo: Padrão State