Pular para o conteúdo principal

Design Patterns - Será que preciso aprender?

O termo Design Patterns (padrões de projeto) foi criado originalmente pelo engenheiro Christopher Alexander para documentar as soluções de projeto comumente utilizados na construção civil. Mais tarde, o termo passou a ser utilizado na área de informática como forma de descrever soluções para problemas encontrados no projeto de software orientado a objetos.

Com o surgimento dos frameworks mais modernos como JBoss Seam, Spring, entre outros, muito se tem discutido a respeito da importância dos Design Patterns.

Na época em que o programador escrevia grande parte do código de controle das aplicações, padrões como Singleton, Façade, DAO, Chain of Responsability, Command, entre outros, eram frequentemente utilizados para criar os pontos de extensão da aplicação, por onde novas funcionalidades podiam ser criadas sem a necessidade de mudanças drásticas no código existente.

Como atualmente a maioria das aplicações é construída sobre um framework, muitos desses padrões já estão incorporados ao projeto por fazerem parte dos frameworks. Por isso, especialistas garantem que nós não precisamos mais utilizar muitos dos Design Patterns existentes.

De fato, se pensarmos em usar os design patterns para resolver os problemas do núcleo da nossa aplicação, realmente eles não precisam ser implementados diretamente pelo programador. Porém, vários Design Patterns vão muito além dessa forma de utilização e apresentam soluções valiosíssimas para questões particulares de cada projeto. Problemas como a necessidade de executar regras específicas com base num modelo de herança complexo ou no estado de um objeto podem ser facilmente resolvidos usando Design Patterns que, além de padronizar o código, oferece facilidades para extender/alterar o modelo futuramente. Alguns exemplos de padrões que atacam essa linha são Strategy, State, Bridge, Decorator, entre outros.

Portanto, mesmo construindo aplicações a partir dos frameworks mais modernos, o conhecimento sobre Design Patterns continua sendo de grande importância para quem trabalha com linguagens orientadas a objetos, como Java, C#, etc.

E mais importante do que saber como implementar um Design Pattern, é saber qual é o problema que você pode resolver com cada padrão. Eu já ouvi várias pessoas dizendo que não entendem os padrões ou que não sabem como fazer uso eficiente deles. Isso certamente acontece porque os problemas resolvidos pelos padrões não são conhecidos.

Para quem quer começar a estudar Design Patterns, a referência principal é o catálogo GoF no livro "Padrões de Projeto - Soluções Reutilizáveis de Software Orientado a Objetos", Gamma E. et al. Esse livro descreve 23 padrões que se aplicam aos mais diferentes problemas de orientação a objetos.

Mas se você for a favor de cursos, relembrando o post do nosso amigo Julio Viegas sobre livro ou curso, a Globalcode tem um minicurso gratuito de 3hs - Introdução a Design Patterns - cujo objetivo é introduzir o conceito de Design Patterns e falar sobre alguns dos padrões mais conhecidos. Uma outra opção, mais apronfundada, é o curso - Core Patterns - de 40hs que trata dos 23 design patterns do GoF e outros 10 do catálogo Java EE BluePrints, com uma abordagem bastante voltada para os problemas resolvidos pelos padrões.

Para quem está lendo esse post em tempo, dia 19 de agosto eu mesma irei ministrar o minicurso de design patterns na Globalcode. Para se inscrever nesse minicurso ou ver outras datas disponíveis acesse o site da Globalcode.

Uma outra fonte de informação é uma entrevista onde comento um pouco mais sobre o que são os Design Patterns e como identificar a necessidade de utilizá-los em nossos projetos.

Comentários

Marcio Duran disse…
Acredito que o assunto pode mesmo também ser debatido em ambito de como eu indentifico o modelo para o think patterns a ser utilizado.

Quero aqui deixar um link que fala sobre algo já discutido nesse portal.

Compondo seu comportamento: herança, Chain of Responsibility e Interceptors

http://blog.caelum.com.br/2010/06/28/compondo-seu-comportamento-heranca-chain-of-responsibility-e-interceptors/

Nesse link foi observado se Singleton não seria o canditado ao patterns de controle.

Nesse outro link são demonstra exemplo em experiência ao Padrões de Projetos.

http://www.javabuilding.com/academy/patterns.html

Dizer que a industria já fornece os desing patterns que já são vinculados em seus frameworks em regra temos um modelo default mas na certa refatorações e transformações vão ocorrer a não ser que já seja algo em propriedade ou lincença para suporte de algum fornecedor.

Postagens mais visitadas deste blog

10 reasons why we love JSF

1. One-slide technology: it's so simple that I can explain basic JSF with one slide. 2. Easy to extend: components, listeners, render kit, Events, Controller, etc. 3. Real-world adoption: JBoss, Exadel, Oracle, IBM, ... 4. Architecture model: you can choose between more than 100 different architecture. 5. Open-mind community: using JSF you are going to meet very interesting people. 6. We are using JSF the last 5 years and we found very good market for JSF in Brazil 7. Progress: look to JSf 1.1 to JSF 1.2, JSF 1.2 to JSF 2.0. People are working really hard! 8. Many professionals now available 9. It's a standard. It's JCP. Before complain, report and help! 10. Ed Burns, spec leader, is an old Globalcode community friend! EXTRA: My wife is specialist in JSF. She's my F1 for JSF :) Nice job JSF community! -Vinicius Senger

EJB 3: Uma evolução sob os conceitos do Hibernate e Spring

Definitivamente o modelo de componentização definido no Java EE 5 e 6 evoluiu e melhorou muito. Mas, sem dúvida muita dessa evolução se deve às pressões do Hibernate e Spring Framework. Estes dois últimos frameworks nasceram baseados no conceito de POJO, que nada mais é do que a concepção de um modelo de componentização baseado em classes Java sem as regras impostas pelo EJB (curioso, sem o EJB não existiria o Hibernate ou o Spring). A morte dos Entity Beans O Hibernate nasceu da idéia de promover um modelo de persistência mais simples que o proposto pelos EJBs do tipo Entity Beans definido na especificação EJB 2.x. Este foi o primeiro tipo de EJB a sofrer com a evasão de desenvolvedores com o surgimento deste framework e a conscientização sobre os problemas nos Entity Beans. A partir de um modelo baseado em JavaBeans e o uso do JDBC, o Hibernate usa a Reflection API para gerar os SQLs necessários para persistir o estado de beans em diversos banco de dados relacionais, além de defini...

O que é Lógica de programação?

Este é o segundo de uma série de posts voltados aos leitores do blog que estão dando início à carreira de desenvolvimento de software. O assunto de hoje é a lógica de programação. Para ler antes: Entendendo como funciona a programação de computadores: linguagens de programação, lógica, banco de dados A lógica de programação é um pré-requisito para quem quer se tornar um desenvolvedor de software, independente da linguagem de programação que se pretende utilizar. Mas o que é de fato a Lógica de Programação e como saber se eu tenho esse pré-requisito? A lógica de programação nada mais é do que a organização coerente das instruções do programa para que seu objetivo seja alcançado. Para criar essa organização, instruções simples do programa, como mudar o valor de uma variável ou desenhar uma imagem na tela do computador, são interconectadas a estruturas lógicas que guiam o fluxo da execução do programa. Isso é muito próximo ao que usamos em nosso cotidiano para realizar atividad...

JavaOne Brasil, dicas para submissão de palestras

Não quero parecer pretensiosa dando dicas para submissão de palestras para o JavaOne Brasil, mas sim repassar os tantos conselhos e sugestões recebidas pelos vetaranos do JavaOne: Bruno Souza e Leonardo Galvão que revisaram dezenas de submissões para o JavaOne e ajudaram a aprovar tantas palestras, e também misturar um pouco da minha experiência na seleção de palestras nos eventos realizados pela Globalcode e SouJava . 10 anos de JavaOne: http://www.globalcode.com.br/noticias/Globalcode10AnosNoJavaOne Os palestrantes ganham a entrada! A submissão pode ser feita em português! O passo mais importante para ser aprovado como palestrante no JavaOne é sem dúvida nenhuma submeter pelo menos uma palestra. Então, independente de qualquer coisa, participe, arrisque, divulgue.  Mas, se quiser aumentar as suas chances...   1) Leve a sério: peça para amigos fazerem uma leitura crítica do texto, e claro uma boa revisão ortográfica. 2) Submissão de várias palestras ou variações do ...

Parceria Globalcode no projeto Samsung Ocean

Já faz algum tempo que a Globalcode e a Samsung tem uma parceria no projeto "Samsung Ocean". Esse é um projeto muito interessante com o objetivo de divulgar e difundir o uso de tecnologia, principalmente associado a dispositivos móveis como celulares e relógios inteligentes (smart watches). No projeto são oferecidos diversos treinamentos e workshops gratuitos . Alguns dos treinamentos oferecidos são: Desenvolvimento de aplicações Android Desenvolvimento de aplicações para wearable Tópicos em desenvolvimento ágil Introdução aos jogos digitais Para a maioria dos cursos, o material e instrutores são fornecidos pela Globalcode. Atualmente nosso grupo de instrutores do projeto conta com excelentes profissionais como: Thiago Moreira Heider Lopes Luis Palma Taynã Bonaldo Thais Andrade O centro de treinamentos está localizado na Escola Politécnica da USP e atualmente estão abertas as inscrições para um dos programas mais bacanas do projeto. É o programa de pré-a...

NIO.2 do Java 7: uma nova API do Java para file system

Uma das novidades mais importantes e aguardadas do Java 7 foi a NIO.2, a nova API para a manipulação I/O com Java. A NIO.2, também conhecida como JSR 203 , disponibiliza um conjunto de novos componentes, projetados para melhorar caracterísiticas de I/O com Java como por exemplo: uma nova API para o acesso e manipulação de conteúdo do file system (sistema de arquivos); outra API para operações assíncronas com I/O; e a atualização da API para comunicação via sockets ( channel sockets ).   O Java, antes da versão 7, tratava a manipulação do sistema de arquivos de forma primitiva. O programador tinha de trabalhar com a classe File para representar arquivos e/ou diretórios, com um número escasso de funcionalidades. Uma operação simples como copiar um arquivo demandava um código relativamente grande. Outras funcionalidades triviais, como por exemplo o uso de links simbólicos, não eram suportadas. Esses são alguns dos motivos para justificar o uso de bibliotecas terceiras...