Padrões de Software (Software Patterns)
|
|
|
- Artur Estrada Madureira
- 10 Há anos
- Visualizações:
Transcrição
1 Padrões de Software (Software Patterns) Cleidson de Souza - [email protected] Departamento de Informática Universidade Federal do Pará Agenda! Definição! Histórico! Motivação! Exemplo Estratégia MVC! Forma de um Padrão! Vantagens! Categorias de Padrões! O Catálogo de Gamma! Exemplos Padrões e Estratégias de Coad O Padrão de Projeto State de Gamma O padrão MVC Idioma de Pree! 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].
2 Histórico! 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 chamadas 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, padrões tem sido amplamente utilizados em todas as fases do processo de 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!!!
3 Motivação 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 Motivação (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, através de trabalho duro e persistente.! Capturar, comunicar e assimilar este conhecimento é difícil Observações! Padrões complementam outras abordagens. Ou seja, eles podem ser utilizados em conjunto com diferentes abordagens para 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 se aplicam apenas à Orientação a Objetos. Por exemplo, podem existir padrões para análise estruturada, aspectos, etc.! Existem padrões organizacionais que sugerem como organizar uma empresa de desenvolvimento de SW, etc [Coplien, 1995].
4 Exemplo: Padrão Estratégia (Strategy) Exemplos! Problema: é necessário mudar facilmente um algoritmo (em tempo de execução).! A idéia básica deste padrão de projeto consiste em encapsular o algoritmo em uma classe isolada. Exemplo: Padrão Estratégia (Strategy) Exemplo: Padrão State! Quando usar: Diferentes variações de um mesmo algoritmo são necessárias; Um algoritmo usa dados que os clientes não deveriam acessar; Uma classe tem d i f e r e n t e s comportamentos, desta forma o padrão pode ser usado ao invés de várias condições;! AStrategy: declara uma interface comum a todos os algoritmos.! ConcreteStrategy: implementa o algoritmo usando a interface definida na superclasse Astrategy.! Context: tem uma referencia para um objeto Astrategy, que é configurado com um objeto ConcreteStrategy.! 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.
5 Exemplo: Padrão State 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. 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 de projetistas experientes, e com isso facilitam o treinamento de novos desenvolvedores;! Formam um vocabulário comum para os projetistas se comunicarem e para a documentação e exploração das alternativas de projeto;
6 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 apresenta, pelo menos, 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.
7 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. Exemplos de Padrões
8 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 Beck)! 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) Classificação de Padrões! Padrões de software 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. Classificação 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
9 Padrões de Arquitetura: 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). O Padrão MVC! O padrão MVC (Model-View-Controller) é um padrão de arquitetura, indicando 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. O Padrão MVC (2)! Este padrão também 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 visão (UI) não devem implementar regras de negócio (modelo).
10 O Padrão MVC (3)! 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. O Padrão MVC (4)! 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. 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. Estes padrões, 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 Coad são famosos padrões de análise.! 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.
11 Exemplo: A abordagem de Coad Padrões de Análise! 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. 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
12 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.). O Catálogo de Gamma Padrões de Projeto Design Patterns: Elements of Reusable Object- Oriented Software por Erich Gamma, Richard Helm, Ralph Johnson, e John Vlissides. Addison Wesley 1994.
13 O Catálogo de Gamma Forma dos Padrões no Catálogo! 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.! 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.! 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 Classificação 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.! 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. 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
14 Idiomas 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. 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.
15 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... 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.! Anti-padrões apresentam também dicas práticas em como detectá-los e como 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.
16 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, Referências: Internet e Conferências! 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, 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
17 Perguntas?
Padrões de Software (Software Patterns)
Padrões de Software (Software Patterns) Cleidson de Souza - [email protected] Departamento de Informática Universidade Federal do Pará Agenda! Definição! Histórico! Considerações! Forma de um Padrão! Exemplo!
Padrões de Projeto. Prof. Jefersson Alex dos Santos ([email protected]) http://www.dcc.ufmg.br/~jefersson
Padrões de Projeto Prof. Jefersson Alex dos Santos ([email protected]) http://www.dcc.ufmg.br/~jefersson Apresentação Conceitos Definição Ponto de vista prático História Padrões de Projeto Conhecidos
Programação Orientada a Objetos. Padrões de Criação
Programação Orientada a Objetos Padrões de Criação Cristiano Lehrer, M.Sc. Objetivos Apresentar cada um dos 23 padrões clássicos descrevendo: O problema que solucionam. A solução. Diagramas UML (Unified
Curso - Padrões de Projeto Módulo 1: Introdução
Curso - Padrões de Projeto Módulo 1: Introdução Vítor E. Silva Souza [email protected] http://www.javablogs.com.br/page/engenho http://esjug.dev.java.net Sobre o Instrutor Formação: Java: Graduação
Padrões de Projeto de Software Orientado a Objetos
Padrões de Projeto de Software Orientado a Objetos Ricardo Argenton Ramos [Baseado nos slides do professor Fabio Kon - USP] 1 Padrões de Projeto de Software OO Também conhecidos como Padrões de Desenho
Prof.ª Esp. Talita Pagani
Especialização em Engenharia de Software Prof.ª Esp. Talita Pagani [email protected] @talitapagani 21/02/2014 Design Patterns Aula 1 Prof.ª Esp. Talita Pagani 1 Informações gerais 1. Definição de Design
J930. Padrões. Projeto. Introdução. argonavis.com.br. Helder da Rocha ([email protected])
Padrões de J930 Projeto Introdução Helder da Rocha ([email protected]) argonavis.com.br O que é um padrão? Maneira testada ou documentada de alcançar um objetivo qualquer Padrões são comuns em várias áreas
1Introdução Helder da Rocha ([email protected])
J930 Padrões Projeto de 1Introdução Helder da Rocha ([email protected]) argonavis.com.br O que é um padrão? Maneira testada ou documentada de alcançar um objetivo qualquer Padrões são comuns em várias áreas
Padrões de projeto 1
Padrões de projeto 1 Design Orientado Objeto Encapsulamento Herança Polimorfismo Design Patterns 2 Responsabilidades Booch e Rumbaugh Responsabilidade é um contrato ou obrigação de um tipo ou classe. Dois
Tópicos Avançados em Engenharia de Software
Faculdade de Ciências e Tecnologia Departamento de Matemática e Computação Programa de Pós-Graduação em Ciência da Computação Tópicos Avançados em Engenharia de Software Padrões e Frameworks (Aula 01-
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 SOFTWARE 1 Jerffeson Teixeira de Souza, Ph.D. Tarciane de Castro Andrade Grupo de Padrões de Software da UECE (GPS.UECE) Julho-2009 CONTEÚDO Introdução aos Padrões de Software O quê são padrões?
Programação Avançada. Padrões de Projeto de Software. Fonte: Oswaldo B. Peres e K19 Treinamentos
Programação Avançada Padrões de Projeto de Software 1 Fonte: Oswaldo B. Peres e K19 Treinamentos Introdução Projetar software OO reusável e de boa qualidade é uma tarefa difícil; Para realizar essa tarefa
Padrões de Desenho (Design Patterns)
Padrões de Desenho (Design Patterns) O que são padrões de desenho Porque são úteis Conhecer alguns padrões 1 Padrões (Patterns) Design Patterns Explained: A New Perspective on Object-Oriented Design, Alan
Padrões GoF. Leonardo Gresta Paulino Murta [email protected]
Padrões GoF Leonardo Gresta Paulino Murta [email protected] Agenda Introdução Padrões de Criação Padrões de Estrutura Padrões de comportamento Leonardo Murta Padrões GoF 2 Introdução Os padrões GoF (Gamma
Padrões de Projeto WEB e o MVC
Padrões de Projeto WEB e o MVC Padrões de Projeto WEB e o MVC O que são padrões? "Cada padrão descreve um problema que ocorre freqüentemente em seu ambiente, e então descreve o cerne da solução para aquele
Design Patterns. Viviane Torres da Silva [email protected]. http://www.ic.uff.br/~viviane.silva/2012.1/es1
Design Patterns Viviane Torres da Silva [email protected] http://www.ic.uff.br/~viviane.silva/2012.1/es1 Sumário Reuso de Software Introdução Benefícios e Desvantagens Visão do Reuso Padrões de Projeto
Testes com Design Patterns
Helder da Rocha ([email protected]) 31 de março de 2005 71. Que padrão de design pode ser usado para permitir que uma implementação específica e uma hierarquia de abstrações possa variar independentemente?
Conteúdo. Disciplina: INF 02810 Engenharia de Software. Monalessa Perini Barcellos. Centro Tecnológico. Universidade Federal do Espírito Santo
Universidade Federal do Espírito Santo Centro Tecnológico Departamento de Informática Disciplina: INF 02810 Prof.: ([email protected]) Conteúdo 1. Introdução 2. Processo de Software 3. Gerência de
PADRÕES DE PROJETO E FRAMEWORK NO DESENVOLVIMENTO DE SOFTWARE
PADRÕES DE PROJETO E FRAMEWORK NO DESENVOLVIMENTO DE SOFTWARE Nelson Ribeiro de Carvalho Júnior 1 RESUMO Atualmente o cenário mundial cuja dependência do software está cada vez mais evidente requer que
Análise e Projeto Orientados por Objetos
Análise e Projeto Orientados por Objetos Apresentação da Disciplina Edirlei Soares de Lima Objetivos da Disciplina Apresentar e discutir técnicas avançadas de Análise e Projeto de
Uma Noção Intuitiva dos Padrões de Desenho de Software
1 1 Uma Noção Intuitiva dos Padrões de Desenho de Software Prof. Dr. Italo S. Vega [email protected] 5 de dezembro de 2001 São Paulo, SP 2 Agenda Motivação (5 min.) Padrões (20 min.) Exemplo (10 min.) Conclusões
Apesar de existirem diversas implementações de MVC, em linhas gerais, o fluxo funciona geralmente da seguinte forma:
1 Introdução A utilização de frameworks como base para a construção de aplicativos tem sido adotada pelos desenvolvedores com três objetivos básicos. Primeiramente para adotar um padrão de projeto que
O que é a UML? Introdução a UML. Objetivos da Modelagem. Modelos. A UML não é. Princípios da Modelagem. O que é um modelo?
O que é a UML? Introdução a UML Linguagem Gráfica de Modelagem para: Visualizar Especificar Construir Documentar Comunicar Artefatos de sistemas complexos Linguagem: vocabulário + regras de combinação
Feature-Driven Development
FDD Feature-Driven Development Descrição dos Processos Requisitos Concepção e Planejamento Mais forma que conteúdo Desenvolver um Modelo Abrangente Construir a Lista de Features Planejar por
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
Padrões de Projeto Disciplina: Engenharia de Software - 2009.1 Professora: Rossana Maria de Castro Andrade Assistente da disciplina: Ricardo Fernandes de Almeida 1 O que é um Padrão? Um padrão descreve
Engenharia de Requisitos
Engenharia de Requisitos Introdução a Engenharia de Requisitos Professor: Ricardo Argenton Ramos Aula 08 Slide 1 Objetivos Introduzir a noção de requisitos do sistema e o processo da engenharia de requisitos.
PRODUTO 1 (CONSTRUÇÃO DE PORTAL WEB)
RELATÓRIO DE ENTREGA DO PRODUTO 1 (CONSTRUÇÃO DE PORTAL WEB) PARA A ELABORAÇÃO DOS PLANOS MUNICIPAIS DE GESTÃO INTEGRADA DE RESÍDUOS SÓLIDOS PMGIRS PARA OS MUNICÍPIOS DE NOVO HORIZONTE, JUPIÁ, GALVÃO,
UML - Unified Modeling Language
UML - Unified Modeling Language Casos de Uso Marcio E. F. Maia Disciplina: Engenharia de Software Professora: Rossana M. C. Andrade Curso: Ciências da Computação Universidade Federal do Ceará 24 de abril
Prototype, um Design Patterns de Criação
Prototype, um Design Patterns de Criação José Anízio Pantoja Maia Este artigo tem como finalidade compreender o funcionamento do padrão de projeto prototype, serão abordados os participantes que compõe
ENGENHARIA DE SOFTWARE I
ENGENHARIA DE SOFTWARE I Prof. Cássio Huggentobler de Costa [[email protected]] Twitter: www.twitter.com/cassiocosta_ Agenda da Aula (002) Metodologias de Desenvolvimento de Softwares Métodos Ágeis
Padrões. Projeto (Design) de Software
Padrões Projeto de Softwares Categorias de Padrões Processo de Tradução de modelos de análise (isentos de tecnologia, lógicos) para modelos de projeto (development-ready, físicos) Qual a Tecnologia Alvo
Modelos de Sistema. 2007 by Pearson Education. Ian Sommerville 2006 Engenharia de Software, 8ª. edição. Capítulo 8 Slide 1.
Modelos de Sistema Ian Sommerville 2006 Engenharia de Software, 8ª. edição. Capítulo 8 Slide 1 Objetivos Explicar por que o contexto de um sistema deve ser modelado como parte do processo de RE Descrever
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)
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) Parte: 1 Prof. Cristóvão Cunha Objetivos de aprendizagem
Desenvolvimento de Sistemas Orientados a Objetos com UML UP/RUP: Projeto
Desenvolvimento de Sistemas Orientados a Objetos com UML UP/RUP: Projeto Engenharia de Software I Informática 2009 Profa. Dra. Itana Gimenes RUP: Artefatos de projeto Modelo de Projeto: Use-Case Realization-projeto
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
DCC / ICEx / UFMG Definição de Padrões Eduardo Figueiredo http://www.dcc.ufmg.br/~figueiredo Um padrão é uma descrição do problema e a essência da sua solução Documenta boas soluções para problemas recorrentes
Desenvolvendo uma Arquitetura de Componentes Orientada a Serviço SCA
Desenvolvendo uma Arquitetura de Componentes Orientada a Serviço SCA RESUMO Ricardo Della Libera Marzochi A introdução ao Service Component Architecture (SCA) diz respeito ao estudo dos principais fundamentos
Engenharia de Software III
Engenharia de Software III Casos de uso http://dl.dropbox.com/u/3025380/es3/aula6.pdf ([email protected]) 09/09/2010 O que são casos de uso? Um caso de uso procura documentar as ações necessárias,
Histórico da Orientação a Objetos Ciclo de vida de Desenvolvimento de SW
Histórico da Orientação a Objetos Ciclo de vida de Desenvolvimento de SW Baseado nos materiais dos profs: Prof.: Edilberto M. Silva http://www.edilms.eti.br Edna Canedo Marcio de Carvalho Victorino Brasília-DF,
SISTEMA TYR DIAGRAMAS DE CLASSE E SEQUÊNCIA Empresa: Academia Universitária
SISTEMA TYR DIAGRAMAS DE CLASSE E SEQUÊNCIA Empresa: Academia Universitária Cascavel Novembro de 2009 Pedro Patitucci Finamore Daniel Bordignon Cassanelli Marco Antonio da Rosa DIAGRAMAS DE CLASSE E SEQUÊNCIA
Pasteur Ottoni de Miranda Junior. Alguns Padrões de Projeto Gamma
Pasteur Ottoni de Miranda Junior Alguns Padrões de Projeto Gamma Padrões Gamma de Projeto(ou Gang-of-Four, gof) Os padrões gof foram publicados por Erich Gamma, Richard Helm, Ralph Johnson e John Vlissides
2 Diagrama de Caso de Uso
Unified Modeling Language (UML) Universidade Federal do Maranhão UFMA Pós Graduação de Engenharia de Eletricidade Grupo de Computação Assunto: Diagrama de Caso de Uso (Use Case) Autoria:Aristófanes Corrêa
Projeto de Sistemas I
Instituto Federal de Educação, Ciência e Tecnologia de São Paulo Projeto de Sistemas I Professora: Kelly de Paula Cunha E-mail:[email protected] Requisitos: base para todo projeto, definindo o
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.
UNIP Sistemas de Informação Análise Essencial de Sistemas Prof.Marcelo Nogueira Análise Essencial de Sistemas 1 Introdução A produção de Software é uma atividade build and fix. Análise Essencial de Sistemas
Análise e Projeto de Sistemas de Informação. Andrêza Leite [email protected]
Análise e Projeto de Sistemas de Informação Andrêza Leite [email protected] Roteiro Sistemas de Informação Ciclo de Desenvolvimento de SI Projeto Análise Estruturada Análise Orientada a Objetos Como
Documento de Arquitetura
Documento de Arquitetura A2MEPonto - SISTEMA DE PONTO ELETRÔNICO A2MEPonto - SISTEMA DE PONTO ELETRÔNICO #1 Pág. 1 de 11 HISTÓRICO DE REVISÕES Data Versão Descrição Autor 28/10/2010 1 Elaboração do documento
Introdução ao Aplicativo de Programação LEGO MINDSTORMS Education EV3
Introdução ao Aplicativo de Programação LEGO MINDSTORMS Education EV3 A LEGO Education tem o prazer de trazer até você a edição para tablet do Software LEGO MINDSTORMS Education EV3 - um jeito divertido
UNIVERSIDADE FEDERAL DO PARANÁ UFPR Bacharelado em Ciência da Computação
SOFT DISCIPLINA: Engenharia de Software AULA NÚMERO: 10 DATA: / / PROFESSOR: Andrey APRESENTAÇÃO O objetivo desta aula é apresentar e discutir os conceitos de coesão e acoplamento. DESENVOLVIMENTO Projetar
Roteiro para a escrita do documento de Especificação de Requisitos de Software (ERS)
Roteiro para a escrita do documento de Especificação de Requisitos de Software (ERS) Definição Geral: Disciplina de Compiladores Prof. Jorge Bidarra (UNIOESTE) A especificação de requisitos tem como objetivo
DISCIPLINA ENGENHARIA DE SOFTWARE Aula 03 Desenvolvimento Ágil Modelos Ágeis. Profª Esp.: Maysa de Moura Gonzaga
DISCIPLINA ENGENHARIA DE SOFTWARE Aula 03 Desenvolvimento Ágil Modelos Ágeis Profª Esp.: Maysa de Moura Gonzaga 2º Semestre / 2011 Extreme Programming (XP); DAS (Desenvolvimento Adaptativo de Software)
Categorias de Padrões
Categorias de Padrões Padrão Arquitetural ou Estilo Arquitetural Padrão de Design (Design Patterns) Idiomas Categorias de Padrões ESTILOS ARQUITETURAIS PADRÕES DE DESIGN IDIOMAS Padrões de Design Os subsistemas
Notas de Aula 04: Casos de uso de um sistema
Notas de Aula 04: Casos de uso de um sistema Objetivos da aula: Aprender os elementos básicos da modelagem por casos de uso Utilizar as associações entre casos de uso, atores e demais artefatos Compreender
ARCO - Associação Recreativa dos Correios. Sistema para Gerenciamento de Associações Recreativas Plano de Desenvolvimento de Software Versão <1.
ARCO - Associação Recreativa dos Correios Sistema para Gerenciamento de Associações Recreativas Versão Histórico da Revisão Data Versão Descrição Autor Página
Mas o que é mesmo Padrão de Projeto?
Mas o que é mesmo Padrão de Projeto? Um Padrão de Projeto descreve uma solução comprovada para um problema recorrente e conhecido no desenvolvimento de software orientado a objetos. Mas afinal, porque
Requisitos de Software
Requisitos de Software Ian Sommerville 2006 Engenharia de Software, 8ª. edição. Capítulo 6 Slide 1 Objetivos Apresentar os conceitos de requisitos de usuário e de sistema Descrever requisitos funcionais
Pós-Graduação em Gerenciamento de Projetos práticas do PMI
Pós-Graduação em Gerenciamento de Projetos práticas do PMI Planejamento do Gerenciamento das Comunicações (10) e das Partes Interessadas (13) PLANEJAMENTO 2 PLANEJAMENTO Sem 1 Sem 2 Sem 3 Sem 4 Sem 5 ABRIL
Análise e Projeto de Software
Análise e Projeto de Software 1 Mundo Real Modelagem Elicitação Análise Problemas Soluções Gap Semântico Mundo Computacional Elicitação de Requisitos Análise de Requisitos Modelagem dos Requisitos 2 Projeto
Concepção e Elaboração
UNIVERSIDADE ESTADUAL PAULISTA INSTITUTO DE BIOCIÊNCIAS, LETRAS E CIÊNCIAS EXATAS DEPARTAMENTO DE CIÊNCIAS DE COMPUTAÇÃO E ESTATÍSTICA Análise e Projeto Orientado a Objetos Concepção e Elaboração Estudo
SOFTWARE PATTERNS: FUNDAMENTOS, TIPOS E DESCRIÇÃO Sérgio Teixeira de Carvalho
SOFTWARE PATTERNS: FUNDAMENTOS, TIPOS E DESCRIÇÃO Sérgio Teixeira de Carvalho Sérgio Teixeira de Carvalho SOFTWARE PATTERNS: FUNDAMENTOS, TIPOS E DESCRIÇÃO Sérgio Teixeira de Carvalho 1 Resumo Especialistas,
Orientação à Objetos. Aécio Costa
Aécio Costa O paradigma da orientação à objetos Paradigma? Um paradigma é uma forma de abordar um problema. No contexto da modelagem de um sistema de software, um paradigma tem a ver com a forma pela qual
PROCESSO DE DESENVOLVIMENTO DE SOFTWARE. Modelos de Processo de Desenvolvimento de Software
PROCESSO DE DESENVOLVIMENTO DE SOFTWARE Introdução Modelos de Processo de Desenvolvimento de Software Os modelos de processos de desenvolvimento de software surgiram pela necessidade de dar resposta às
Governança de TI. ITIL v.2&3. parte 1
Governança de TI ITIL v.2&3 parte 1 Prof. Luís Fernando Garcia [email protected] ITIL 1 1 ITIL Gerenciamento de Serviços 2 2 Gerenciamento de Serviços Gerenciamento de Serviços 3 3 Gerenciamento de Serviços
Glossário Apresenta a definição dos termos, siglas e abreviações utilizadas no contexto do projeto Citsmart.
Apresenta a definição dos termos, siglas e abreviações utilizadas no contexto do projeto Citsmart. Versão 1.6 15/08/2013 Visão Resumida Data Criação 15/08/2013 Versão Documento 1.6 Projeto Responsáveis
MVC e Camadas - Fragmental Bliki
1 de 5 20-03-2012 18:32 MVC e Camadas From Fragmental Bliki Conteúdo 1 Introdução 2 Camadas: Separação Entre Componentes 3 MVC: Interação Entre Componentes 4 Conclusão 5 Referências Introdução A Arquitetura
PADRÕES DE PROJETO. Cleviton Monteiro ([email protected])
PADRÕES DE PROJETO Cleviton Monteiro ([email protected]) Roteiro Atributos de qualidade Boas práticas de projeto Code Smell Padrões de Projeto Atributos de qualidade Coesão Acoplamento Atributos de qualidade
Programação com Objectos
Programação com Objectos PADRÕES DE DESENHO Classificaçã Objectivo Criação Estrutura Comportamento Introdução Alguns Padrões de Desenho Classe Factory Method Adapter Interpreter Template Method O que é
Modelagemde Software Orientadaa Objetos com UML
Modelagemde Software Orientadaa Objetos com UML André Maués Brabo Pereira Departamento de Engenharia Civil Universidade Federal Fluminense Colaborando para a disciplina CIV 2802 Sistemas Gráficos para
Requisitos de Software
Requisitos de Software Centro de Informática - Universidade Federal de Pernambuco Kiev Gama [email protected] Slides originais elaborados por Ian Sommerville e adaptado pelos professores Márcio Cornélio,
Curso - Padrões de Projeto Módulo 2: Padrões de Criação
Curso - Padrões de Projeto Módulo 2: Padrões de Criação Vítor E. Silva Souza [email protected] http://www.javablogs.com.br/page/engenho http://esjug.dev.java.net Sobre o Instrutor Formação: Java: Graduação
Padrões. Identificando padrões
Padrões Padrões são soluções para problemas específicos que ocorrem de forma recorrente em um determinado contexto que foram identificados a partir da experiência coletiva de desenvolvedores de software.
Relatório do GPES. Arquitetura Geral do Framework
Relatório do GPES UNIVERSIDADE TECNOLÓGICA FEDERAL DO PARANÁ Relatório referente ao desenvolvimento da arquitetura geral do framework de preço de venda. Realizado no período de 29 de junho de 2010 a 30
Capítulo 2. Processos de Software. 2011 Pearson Prentice Hall. Todos os direitos reservados. slide 1
Capítulo 2 Processos de Software slide 1 Tópicos apresentados Modelos de processo de software. Atividades de processo. Lidando com mudanças. Rational Unified Process (RUP). Um exemplo de um processo de
UFG - Instituto de Informática
UFG - Instituto de Informática Curso: Sistemas de Informação Arquitetura de Software Prof.: Fabrízzio A A M N Soares [email protected] Aula 3 Introdução à Arquitetura de Software (continuação)
Felipe Denis M. de Oliveira. Fonte: Alice e Carlos Rodrigo (Internet)
UML Felipe Denis M. de Oliveira Fonte: Alice e Carlos Rodrigo (Internet) 1 Programação O que é UML? Por quê UML? Benefícios Diagramas Use Case Class State Interaction Sequence Collaboration Activity Physical
FUNDAMENTOS DE SISTEMAS DE INFORMAÇÃO
FUNDAMENTOS DE SISTEMAS DE Rafael D. Ribeiro, M.Sc,PMP. [email protected] http://www.rafaeldiasribeiro.com.br Princípios da Teoria de Sistemas 1 Grupos diferentes dentro de uma organização necessitam
Sumário. Uma visão mais clara da UML
Instituto Federal de Santa Catarina Câmpus Chapecó Ensino Médio Integrado em Informática Módulo V Unidade Curricular: Engenharia de Software Professora: Lara P. Z. B. Oberderfer Uma visão mais clara da
Tópicos em Engenharia de Software (Optativa III) AULA 2. Prof. Andrêza Leite [email protected] (81 )9801-6619
Tópicos em Engenharia de Software (Optativa III) AULA 2 Prof. Andrêza Leite [email protected] (81 )9801-6619 Engenharia de Software Objetivo da aula Depois desta aula você terá uma revisão sobre o
Aplicativo web para definição do modelo lógico no projeto de banco de dados relacional
Aplicativo web para definição do modelo lógico no projeto de banco de dados relacional Juarez Bachmann Orientador: Alexander Roberto Valdameri Roteiro Introdução Objetivos Fundamentação teórica Desenvolvimento
2 Engenharia de Software
20 2 Engenharia de Software 2.1 Design de Sistemas Orientados a Objetos Os Sistemas Orientados a Objetos não são mais novidade hoje em dia já estando há muitos anos no mercado. A orientação a objetos permite
Arquitetura de Software. Silvia Regina Vergilio
Arquitetura de Software Silvia Regina Vergilio Atividades de Projeto Projeto Geral ou Preliminar: fase que traduz a especificação do sistema em termos da arquitetura de dados e de módulos. Descreve a organização
Wilson Moraes Góes. Novatec
Wilson Moraes Góes Novatec Copyright 2014 Novatec Editora Ltda. Todos os direitos reservados e protegidos pela Lei 9.610 de 19/02/1998. É proibida a reprodução desta obra, mesmo parcial, por qualquer processo,
3 Um Framework Orientado a Aspectos para Monitoramento e Análise de Processos de Negócio
32 3 Um Framework Orientado a Aspectos para Monitoramento e Análise de Processos de Negócio Este capítulo apresenta o framework orientado a aspectos para monitoramento e análise de processos de negócio
Agenda da Aula. Resumo dos Padrões (Aula 4) Padrões Arquiteturais. Arquitetura Cliente-Servidor. Arquitetura Cliente-Servidor
Reuso de Software Aula 05 Agenda da Aula Linha de Produtos de Software Eduardo Figueiredo http://www.dcc.ufmg.br/~figueiredo [email protected] 19 Março 2012 Padrões arquiteturais Cliente-Servidor
do grego: arkhé (chefe ou mestre) + tékton (trabalhador ou construtor); tekhne arte ou habilidade;
1 ARQUITETURA E DESIGN DE SOFTWARE O que é Arquitetura? do grego: arkhé (chefe ou mestre) + tékton (trabalhador ou construtor); tekhne arte ou habilidade; do dicionário: Arte de projetar e construir prédios,
Análise e Projeto Orientados por Objetos
Análise e Projeto Orientados por Objetos Aula 02 Análise e Projeto OO Edirlei Soares de Lima Análise A análise modela o problema e consiste das atividades necessárias para entender
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
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 Cronograma das Aulas. Hoje você está na aula Semana
Engenharia de Requisitos Estudo de Caso
Engenharia de Requisitos Estudo de Caso Auxiliadora Freire Fonte: Engenharia de Software 8º Edição / Ian Sommerville 2007 Slide 1 Engenharia de Requisitos Exemplo 1 Reserva de Hotel 1. INTRODUÇÃO Este
DESENVOLVIMENTO DE INTERFACE WEB MULTIUSUÁRIO PARA SISTEMA DE GERAÇÃO AUTOMÁTICA DE QUADROS DE HORÁRIOS ESCOLARES. Trabalho de Graduação
DESENVOLVIMENTO DE INTERFACE WEB MULTIUSUÁRIO PARA SISTEMA DE GERAÇÃO AUTOMÁTICA DE QUADROS DE HORÁRIOS ESCOLARES Trabalho de Graduação Orientando: Vinicius Stein Dani [email protected] Orientadora: Giliane
4 O Workflow e a Máquina de Regras
4 O Workflow e a Máquina de Regras O objetivo do workflow e da máquina de regras é definir um conjunto de passos e regras configuráveis. Ao longo de sua execução, um usuário consegue simplificar o seu
Casos de Uso O que é. Casos de Uso. Objetivos de um Caso de Uso. Atores. Atores e Casos de Uso. Diagramas de Caso de Uso
Casos de Uso O que é Casos de Uso Descrições narrativas de processos do domínio da aplicação Documentam a seqüência de eventos de um ator (um agente externo) usando o sistema para completar, do início
REQUISITOS. Prof. Msc. Hélio Esperidião
REQUISITOS Prof. Msc. Hélio Esperidião OS REQUISITOS O que são requisitos? Uma descrição de um serviço ou de uma limitação O que é a engenharia de requisitos? O processo envolvido no desenvolvimento de
Proposta para a Implementação do Cadastro de um Log de Auditoria Baseada em Padrões de Projeto
FACULDADE CAMPO LIMPO PAULISTA BACHARELADO EM CIÊNCIA DA COMPUTAÇÃO Trabalho de Diplomação Gabriel Augusto Gimenes 9881 André Marcos Silva (Orientador) Trabalho de Diplomação Proposta para a Implementação
Programação Estruturada e Orientada a Objetos. Fundamentos Orientação a Objetos
Programação Estruturada e Orientada a Objetos Fundamentos Orientação a Objetos 2013 O que veremos hoje? Introdução aos fundamentos de Orientação a Objetos Transparências baseadas no material do Prof. Jailton
Diagrama de Classes. Diagrama de Classes. Diagramas de Classe. POST Criando Diagramas de Classe. Como construir (2)
Diagrama de Classes Diagrama de Classes Modelo de classes de especificação Perspectiva de Projeto Ilustra as especificações de software para as classes e interfaces do sistema. É obtido através da adição
Conteúdo. Disciplina: INF 02810 Engenharia de Software. Monalessa Perini Barcellos
Universidade Federal do Espírito Santo Centro Tecnológico Departamento de Informática Disciplina: INF 02810 Prof.: ([email protected]) Conteúdo 1. Introdução 2. Processo de Software 3. Gerência de
