Seis Benefícios da Arquitetura de Software (bem-feita!)

Neste post, compartilho seis benefícios gerados por um bom projeto de Arquitetura de Software.  Cada um desses benefícios ajuda a gerar ótimos sistemas. Além disso, são facilmente compreendidos e bem avaliados pelos stakeholders.

Esta relação é inspirada em uma proposta de Michael Keeling, no excelente livro “Design It!”.

1. Problemas grandes fracionados em partes menores e gerenciáveis

Gosto de definir arquitetura de software como sendo a relação dos componentes de uma aplicação, a descrição de suas responsabilidades e da forma como se relacionam.

Sistemas modernos são grandes e complexos. Uma boa arquitetura de software, ajuda a explicar como um sistema poderia e ser particionado em componentes, reduzindo, assim, a complexidade para seu entendimento.

Componentes coesos e bem definidos podem operar de forma quase independente. Da mesma forma, podem ser desenvolvidos por times especialistas que podem, então, se aprofundar em especificidades do negócio.

2. Facilidade para formar times de trabalho

Desenvolvimento de Software é uma atividade humana. Uma boa arquitetura de software descreve como os diversos componentes de um sistema devem operar e como eles devem se comunicar. Com essa perspectiva, é mais fácil pensar em como estruturar times que os irão desenvolver.

Quando conhecemos a arquitetura, podemos pensar em como as pessoas podem colaborar para desenvolver o software. Quanto maior o sistema, mais importante torna-se a arquitetura. (Michael Keeling)

3. Vocabulário para o debate de temas complexos

Comunicação é um aspecto chave para o trabalho em equipe.

No lugar de gastar horas inventando um vocabulário e conceitos, podemos usar os conceitos e vocabulários essenciais descobertos na arquitetura como base para a colaboração. (Michael Keeling)

De tudo que aprendi sobre Domain-Driven Design, o que mais gosto e vejo frequentemente subestimado é o conceito de Linguagem Ubíqua. Trata-se de uma idéa fácil de entender, mas raramente bem implementada – talvez pela aparente facilidade.

O tempo gasto na explicitação da linguagem ubíqua é mais do que compensado na melhoria do entendimento do negócio e aperfeiçoamento da arquitetura. Aliás, quanto mais íntima for a implementação, menores as chances de corrosão da arquitetura.

4. Visão além de Features e Funcionalidades

Features e funcionalidades são muito importantes, sem dúvidas. Mas elas não são os únicos elementos que determinam se um software é bom ou não.

Quando pensamos em arquitetura, temos que considear elementos como custo, restrições, agendas, riscos e a habilidade do time para entregar o que está sendo pedido. Por exemplo, nem sempre a linguagem mais “natural” para expressar o domínio do problema é a escolha acertada para um projeto – temos que considerar o custo de preparar o time para usar a linguagem.

5. Erros Caros são mais facilmente evitados

Pense no seguinte:

Arquitetura de software são as coisas importantes de um software. O que quer que isso seja. (Martin Fowler)

Podemos interpretar coisas importantes como aquelas com alto custo para mudança.  A visão holística do sistema permite a quem está definindo a arquitetura (arquiteto?) identificar onde estão os aspectos críticos e potenciais dificuldades.

Em minha experiência, o Princípio de Pareto se aplica perfeitamente ao conjunto de elementos de um sistema. 20% deles são responsáveis por 80% da dificuldade (são os “pontos de dor” do sistema).  Arquitetura de software bem-feita deixa explícito quais são esses 20%.

6. Agilidade

Michael Keeling compara a forma como software responde a mudança a água – contornando obstáculos.

Se software é como água, que se ajusta a qualquer recepiente, então a arquitetura do software é o recepiente que dá forma ao software. (Michel Keeling).

Assim como a água, um software sem uma definição arquitetônica, segue o caminho que oferece menos resistência de forma incontrolável. A arquitetura de software fornece a estrutura para que a mudança seja possível.

Sem facilidade para suportar mudanças, não há agilidade.

Concluindo

Nesse post falei sobre seis benefícios oriundos de arquitetura de software bem-feita. Há outras ideias que poderiam ser exploradas. Mas, essas são mais do que suficientes para justificar o pensamento arquitetônico de forma planejada.

 

Compartilhe este insight:

Elemar Júnior

Sou fundador e CEO da EximiaCo e atuo como tech trusted advisor ajudando diversas empresas a gerar mais resultados através da tecnologia.

Elemar Júnior

Sou fundador e CEO da EximiaCo e atuo como tech trusted advisor ajudando diversas empresas a gerar mais resultados através da tecnologia.

Mais insights para o seu negócio

Veja mais alguns estudos e reflexões que podem gerar alguns insights para o seu negócio:

In this post, let’s solve the “Euler Knight’s Tour” using F#. Disclaimer Sometimes life imposes a pause on us. I’m...
Empresas modernas, com estilo de gestão diferente e resultados espetaculares, estão desafiando tudo o que sabemos sobre estratégia e execução....
This is the first of a series of blog posts sharing some knowledge about how to develop a real-world software...
In this post, let’s talk about how to implement Value Types correctly and improve the performance of your applications. The...
The following works as expected when building in Debug – the execution is done after three seconds. But, for some...
Nem todos os problemas podem ser resolvidos da mesma forma. Nem toda ferramenta é apropriada para todo tipo de trabalho....

Curso Reputação e Marketing Pessoal

Masterclasses

01

Introdução do curso

02

Por que sua “reputação” é importante?

03

Como você se apresenta?

04

Como você apresenta suas ideias?

05

Como usar Storytelling?

06

Você tem uma dor? Eu tenho o alívio!

07

Escrita efetiva para não escritores

08

Como aumentar (e manter) sua audiência?

09

Gatilhos! Gatilhos!

10

Triple Threat: Domine Produto, Embalagem e Distribuição

11

Estratégias Vencedoras: Desbloqueie o Poder da Teoria dos Jogos

12

Análise SWOT de sua marca pessoal

13

Soterrado por informações? Aprenda a fazer gestão do conhecimento pessoal, do jeito certo

14

Vendo além do óbvio com a Pentad de Burkle

15

Construindo Reputação através de Métricas: A Arte de Alinhar Expectativas com Lag e Lead Measures

16

A Tríade da Liderança: Navegando entre Líder, Liderado e Contexto no Mundo do Marketing Pessoal

17

Análise PESTEL para Marketing Pessoal

18

Canvas de Proposta de Valor para Marca Pessoal

19

Método OKR para Objetivos Pessoais

20

Análise de Competências de Gallup

21

Feedback 360 Graus para Autoavaliação

22

Modelo de Cinco Forças de Porter

23

Estratégia Blue Ocean para Diferenciação Pessoal

24

Análise de Tendências para Previsão de Mercado

25

Design Thinking para Inovação Pessoal

26

Metodologia Agile para Desenvolvimento Pessoal

27

Análise de Redes Sociais para Ampliar Conexões

Lições complementares

28

Apresentando-se do Jeito Certo

29

O mercado remunera raridade? Como evidenciar a sua?

30

O que pode estar te impedindo de ter sucesso

Recomendações de Leituras

31

Aprendendo a qualificar sua reputação do jeito certo

32

Quem é você?

33

Qual a sua “IDEIA”?

34

StoryTelling

35

Você tem uma dor? Eu tenho o alívio!

36

Escrita efetiva para não escritores

37

Gatilhos!

38

Triple Threat: Domine Produto, Embalagem e Distribuição

39

Estratégias Vencedoras: Desbloqueie o Poder da Teoria do Jogos

40

Análise SWOT de sua marca pessoal

Inscrição realizada com sucesso!

No dia da masterclass você receberá um e-mail com um link para acompanhar a aula ao vivo. Até lá!

A sua subscrição foi enviada com sucesso!

Aguarde, em breve entraremos em contato com você para lhe fornecer mais informações sobre como participar da mentoria.

Masterclass
15/07

Pare de dar a solução certa para o problema errado

Muita gente boa quebra a cabeça por dias tentando resolver o que não estava quebrado, simplesmente por tentar dar a resposta certa pro problema errado, mas precisa realmente ser assim?

Crie sua conta

Preencha os dados para iniciar o seu cadastro no plano anual do Clube de Estudos:

Crie sua conta

Preencha os dados para iniciar o seu cadastro no plano mensal do Clube de Estudos:

× Precisa de ajuda?