SlideShare uma empresa Scribd logo
Implementação, design
ou arquitetura?
Desenhar sistemas é uma tarefa difícil
E, ainda fazer com que sejam
escaláveis e performáticos,
mantendo uma alta qualidade
interna e externa, é um desafio!
“Você deve enfrentar suas batalhas
de design, sejam elas no nível
macroarquitetural ou no humilde
campo das instâncias”
Craig Larman
Qual é a diferença de design e
arquitetura de software?
design é feito em cima
do que foi decidido
pela arquitetura
por isso o que faz parte
da arquitetura é mais
difícil de mudar
“Alguns padrões podem ser chamados
arquiteturais, já que representam decisões
importantes sobre essas partes; outros são
mais sobre design e o ajudam a
implementar essa arquitetura”
Martin Fowler
“Alguns padrões podem ser chamados
arquiteturais, já que representam decisões
importantes sobre essas partes; outros são
mais sobre design e o ajudam a
implementar essa arquitetura”
Martin Fowler
“Não faço nenhuma forte
tentativa de separar esses
dois, uma vez que aquilo
que é arquitetural ou não é
subjetivo”
'
“o termo arquitetura envolve a
noção dos principais elementos do
sistema, as peças que são mais
difíceis de mudar”
Arquiteturas são as decisões
que gostaríamos de ter
tomado no começo do
projeto
Ralph Johnson (do GoF)
Implementação, design ou arquitetura?
Implementação, design ou arquitetura?
Implementação, design ou arquitetura?
Implementação, design ou arquitetura?
Uma vez que somente
implementações são concretas,
todo tipo de mudança implica em
conhecer a implementação!
Implementação, design ou arquitetura?
Implementação, design ou arquitetura?
public class Conta {
private BigDecimal saldo = BigDecimal.ZERO;
private BigDecimal limite = BigDecimal.ZERO;
private Cliente titular;
private int numero;
private Calendar dataAbertura;
public void setNumero(int numero) {
this.numero = numero;
}
public void setDataAbertura(Calendar dataAbertura) {
this.dataAbertura = dataAbertura;
}
public int getNumero() {
return numero;
}
public Calendar getDataAbertura() {
return dataAbertura;
}
…
public class Conta {
private BigDecimal saldo = BigDecimal.ZERO;
private BigDecimal limite = BigDecimal.ZERO;
private Cliente titular;
private int numero;
private Calendar dataAbertura;
public Conta(int numero, Calendar dataAbertura) {
setNumero(numero);
setDataAbertura(dataAbertura);
}
private void setNumero(int numero) {
this.numero = numero;
}
private void setDataAbertura(Calendar dataAbertura) {
this.dataAbertura = dataAbertura;
}
public int getNumero() {
return numero;
}
public class Conta {
private BigDecimal saldo = BigDecimal.ZERO;
private BigDecimal limite = BigDecimal.ZERO;
private Cliente titular;
private int numero;
private Calendar dataAbertura;
public Conta(int numero, Calendar dataAbertura, BigDecimal saldoInicial,
MaisUmMonteDeParametros... ) {
setNumero(numero);
setDataAbertura(dataAbertura);
setSaldo(saldoInicial);
…
}
private void setNumero(int numero) {
this.numero = numero;
}
private void setDataAbertura(Calendar dataAbertura) {
this.dataAbertura = dataAbertura;
}
public class TestaBuilder {
public static void main(String[] args) {
Conta conta = ContaBuilder.novaConta()
.comNumero(456)
.comDataDeAbertura(2012, 04, 20)
.eDepositoInicial("100")
.toConta();
conta.saca(new BigDecimal("50"));
System.out.println(conta.getSaldo());
}
}
Uma boa implementação,
design ou arquitetura:
É aquela que permite modificações
causando somente um impacto
considerado justo a outras partes do
sistema
Conhecer profundamente as
ferramentas é o primeiro passo
para poder fazer as perguntas
corretas ao enfrentar o cenário
de uma nova aplicação
Por onde começar?
Boas práticas de OO
TDD – Test-Driven Design
“Vale lembrar que precisamos de
mais de 10 mil horas, ou 10 anos,
para dominar uma linguagem”
Peter Norvig

Mais conteúdo relacionado

PDF
Robustez de Software - Como ouvir menos reclamações dos seus chefes
PDF
Dicas para deixar seu código mais Robusto
PDF
Os desafios de um chat integrado ao checkout
PDF
Cultura na engenharia & Impacto no recrutamento
PDF
Arquitetura e Design QCon2010 - Paulo Silveira - Caelum
PPT
Domain Driven Design (DDD) - DevIsland, BH
PPSX
TDD e Clean Code
Robustez de Software - Como ouvir menos reclamações dos seus chefes
Dicas para deixar seu código mais Robusto
Os desafios de um chat integrado ao checkout
Cultura na engenharia & Impacto no recrutamento
Arquitetura e Design QCon2010 - Paulo Silveira - Caelum
Domain Driven Design (DDD) - DevIsland, BH
TDD e Clean Code

Semelhante a Implementação, design ou arquitetura? (20)

ODP
Dojo de programação - Dia de Java - UFSCar
PPT
[CLPE] Design patterns com c#
PPTX
Lecture 5 :: Planejameto Temporal e Monitorização do Projeto
PDF
Por quê você deve utilizar TDD?
PPT
Workshop Rational Team Concert - RTC - Planejamento - aula 01
PDF
Combatendo code smells em aplicações Java
ODP
Revolucao Agile - UFSCar
PPTX
Shift left DevOps Experience
PPT
Planeamento Temporal E Monitorização do Projecto de SW
PPT
Estimativas cef 2000
PPT
Integração dados prática ppt
PDF
Solid works 2007
PDF
A24 paper - perfil business intelligence - o momento de sair da rotina por ...
PDF
A24 paper - perfil business intelligence - o momento de sair da rotina por ...
PPTX
Modelagem Dimensional
PDF
TDC2016 Boas Práticas SQL em Banco Relacional para Desenvolvedores
PPTX
A03_BD_Transformacao_MER_Relacional.pptx
PDF
O Projecto, Gestão de Projectos e o Gestor de Projectos - Parte 1
PPTX
Treinamento - Product Owner - CLARO-NET-EMBRATEL
PDF
Refatoração de código com Capitão Nascimento versão completa
Dojo de programação - Dia de Java - UFSCar
[CLPE] Design patterns com c#
Lecture 5 :: Planejameto Temporal e Monitorização do Projeto
Por quê você deve utilizar TDD?
Workshop Rational Team Concert - RTC - Planejamento - aula 01
Combatendo code smells em aplicações Java
Revolucao Agile - UFSCar
Shift left DevOps Experience
Planeamento Temporal E Monitorização do Projecto de SW
Estimativas cef 2000
Integração dados prática ppt
Solid works 2007
A24 paper - perfil business intelligence - o momento de sair da rotina por ...
A24 paper - perfil business intelligence - o momento de sair da rotina por ...
Modelagem Dimensional
TDC2016 Boas Práticas SQL em Banco Relacional para Desenvolvedores
A03_BD_Transformacao_MER_Relacional.pptx
O Projecto, Gestão de Projectos e o Gestor de Projectos - Parte 1
Treinamento - Product Owner - CLARO-NET-EMBRATEL
Refatoração de código com Capitão Nascimento versão completa
Anúncio

Mais de David Robert Camargo de Campos (12)

PDF
Evolução cultural - Criando Times de Alto Desempenho
PDF
Evolução cultural - Criando times de alto desempenho
PDF
Introdução ao kotlin
PDF
O uso de PWA e o futuro do desenvolvimento mobile com React Native e Kotlin
PDF
Evolução cultural: Criando times de alto desempenho no Elo7
PDF
Times de Alta Performance
PDF
PDF
An introduction to programming in Go
PDF
Lidando com Java obsoleto: do Struts 1.0 ao CDI - QConSP 2014
PDF
Como um grande sistema REST funciona - arquitetura e desempenho
PDF
Construindo um sistema distribuido usando rest
PPT
Como um grande sistema REST funciona
Evolução cultural - Criando Times de Alto Desempenho
Evolução cultural - Criando times de alto desempenho
Introdução ao kotlin
O uso de PWA e o futuro do desenvolvimento mobile com React Native e Kotlin
Evolução cultural: Criando times de alto desempenho no Elo7
Times de Alta Performance
An introduction to programming in Go
Lidando com Java obsoleto: do Struts 1.0 ao CDI - QConSP 2014
Como um grande sistema REST funciona - arquitetura e desempenho
Construindo um sistema distribuido usando rest
Como um grande sistema REST funciona
Anúncio

Implementação, design ou arquitetura?

  • 2. Desenhar sistemas é uma tarefa difícil
  • 3. E, ainda fazer com que sejam escaláveis e performáticos, mantendo uma alta qualidade interna e externa, é um desafio!
  • 4. “Você deve enfrentar suas batalhas de design, sejam elas no nível macroarquitetural ou no humilde campo das instâncias” Craig Larman
  • 5. Qual é a diferença de design e arquitetura de software?
  • 6. design é feito em cima do que foi decidido pela arquitetura por isso o que faz parte da arquitetura é mais difícil de mudar
  • 7. “Alguns padrões podem ser chamados arquiteturais, já que representam decisões importantes sobre essas partes; outros são mais sobre design e o ajudam a implementar essa arquitetura” Martin Fowler
  • 8. “Alguns padrões podem ser chamados arquiteturais, já que representam decisões importantes sobre essas partes; outros são mais sobre design e o ajudam a implementar essa arquitetura” Martin Fowler “Não faço nenhuma forte tentativa de separar esses dois, uma vez que aquilo que é arquitetural ou não é subjetivo”
  • 9. '
  • 10. “o termo arquitetura envolve a noção dos principais elementos do sistema, as peças que são mais difíceis de mudar”
  • 11. Arquiteturas são as decisões que gostaríamos de ter tomado no começo do projeto Ralph Johnson (do GoF)
  • 16. Uma vez que somente implementações são concretas, todo tipo de mudança implica em conhecer a implementação!
  • 19. public class Conta { private BigDecimal saldo = BigDecimal.ZERO; private BigDecimal limite = BigDecimal.ZERO; private Cliente titular; private int numero; private Calendar dataAbertura; public void setNumero(int numero) { this.numero = numero; } public void setDataAbertura(Calendar dataAbertura) { this.dataAbertura = dataAbertura; } public int getNumero() { return numero; } public Calendar getDataAbertura() { return dataAbertura; } …
  • 20. public class Conta { private BigDecimal saldo = BigDecimal.ZERO; private BigDecimal limite = BigDecimal.ZERO; private Cliente titular; private int numero; private Calendar dataAbertura; public Conta(int numero, Calendar dataAbertura) { setNumero(numero); setDataAbertura(dataAbertura); } private void setNumero(int numero) { this.numero = numero; } private void setDataAbertura(Calendar dataAbertura) { this.dataAbertura = dataAbertura; } public int getNumero() { return numero; }
  • 21. public class Conta { private BigDecimal saldo = BigDecimal.ZERO; private BigDecimal limite = BigDecimal.ZERO; private Cliente titular; private int numero; private Calendar dataAbertura; public Conta(int numero, Calendar dataAbertura, BigDecimal saldoInicial, MaisUmMonteDeParametros... ) { setNumero(numero); setDataAbertura(dataAbertura); setSaldo(saldoInicial); … } private void setNumero(int numero) { this.numero = numero; } private void setDataAbertura(Calendar dataAbertura) { this.dataAbertura = dataAbertura; }
  • 22. public class TestaBuilder { public static void main(String[] args) { Conta conta = ContaBuilder.novaConta() .comNumero(456) .comDataDeAbertura(2012, 04, 20) .eDepositoInicial("100") .toConta(); conta.saca(new BigDecimal("50")); System.out.println(conta.getSaldo()); } }
  • 23. Uma boa implementação, design ou arquitetura: É aquela que permite modificações causando somente um impacto considerado justo a outras partes do sistema
  • 24. Conhecer profundamente as ferramentas é o primeiro passo para poder fazer as perguntas corretas ao enfrentar o cenário de uma nova aplicação
  • 25. Por onde começar? Boas práticas de OO TDD – Test-Driven Design
  • 26. “Vale lembrar que precisamos de mais de 10 mil horas, ou 10 anos, para dominar uma linguagem” Peter Norvig