Este artigo apresenta uma visão geral de conceitos relacionados à injeção de dependência e como seu uso pode ser útil na construção de aplicações Java simples e bem estruturadas. Veremos como é possível construir soluções onde o gerenciamento de conexões entre componentes é feito de forma simplificada e flexível, reduzindo o acoplamento entre as diversas partes do sistema.
Além disso, vamos ver como a injeção de dependência (DI) disponível na plataforma Java EE facilita a organização de componentes. Organizar e gerenciar o relacionamento entre componentes de uma solução é uma condição fundamental para manter a mesma de forma organizada e lógica.
Como sabemos, um projeto de software consiste em transformar um conjunto de requisitos em uma solução. E para atingir esse objetivo, muitas vezes separamos esses requisitos em diversos elementos, ou componentes, que possuem um conjunto de responsabilidades e colaboram para viabilizar as diferentes funcionalidades. Observe que usamos aqui a noção de componente de forma bem abrangente (e vamos continuar utilizando no texto a seguir), não implicando na adoção de uma determinada estrutura ou tecnologia, mas apenas a ideia de que a realização dos requisitos seja feita fragmentando e realizando os mesmos em diversos módulos, ao invés de em um único elemento.
Outro nome para essa separação é modularização, técnica usada há bastante tempo como parte da estratégia de separar grandes problemas em problemas menores e mais fáceis de serem resolvidos, alocando responsabilidades específicas e relacionadas a determinados componentes.
Ao realizarmos essa divisão de responsabilidades entre diversos componentes da solução, podemos avaliar a qualidade dessa separação e da interação entre os componentes através de duas medidas: coesão e acoplamento. De forma geral, devemos buscar projetar e construir componentes com alto grau de coesão e baixo acoplamento, pois isso facilita a compreensão e manutenção da solução.
Coesão e acoplamento
Coesão e acoplamento não são conceitos novos no desenvolvimento de software e muito menos exclusivos da plataforma Java. Ao contrário, são conceitos que estão por aí desde meados de 1960 e que, volta e meia, são alvo de novas e engenhosas propostas de solução. Para entender como a injeção de dependência se encaixa nesse contexto, vamos falar um pouco sobre coesão, acoplamento e outros conceitos relacionados.
E por que esses conceitos são importantes e recorrentes? Porque nenhum componente é uma ilha: Qualquer sistema, a partir de um grau mínimo de complexidade, será composto por diversas peças que colaboram entre si, e gerenciar essa complexidade em diversos níveis é um problema recorrente no desenvolvimento de software. Considere as dependências que existem entre métodos, classes, componentes, bibliotecas e aplicações. Para cada um desses tipos de relacionamento podemos ter estratégias distintas para facilitar a redução de acoplamento e aumentar a coesão.
Coesão
Coesão mede o quanto as responsabilidades de um determinado componente estão relacionadas ao mesmo. Quanto maior a coesão, melhor o projeto do elemento.
Como definimos um componente de forma ampla, vamos usar como exemplo um método de uma classe. Uma forma de avaliar o nível de coesão do mesmo seria a seguinte: Todas as linhas de código desse método são relacionadas ao objetivo do mesmo? Você consegue dizer que o método possui uma única responsabilidade, e que toda a sua estrutura contribui para essa responsabilidade, ou consegue identificar diversas responsabilidades distintas nesse método?
Por exemplo, em um mesmo método, você pode acessar um banco de dados, validar as informações contra um serviço externo, formatar os dados para exibição em uma tela e verificar se o usuário dessa aplicação possui perfil de administrador ou usuário comum. Muita coisa? Sim, e você pode identificar facilmente métodos assim, verificando, por exemplo, os que são mais extensos ou que fazem diversas “coisas”. Esses são métodos que comumente apresentam baixa coesão, característica normalmente encontrada onde diversas responsabilidades são “amarradas” em um mesmo elemento.
De maneira mais ampla, dessa vez analisando a classe, considere se os métodos da mesma são relacionados. Uma mesma classe é responsável pelos diversos aspectos descritos anteriormente, ou você consegue determinar a responsabilidade de uma classe como única? A facilidade com que consegue responder a essa pergunta pode determinar se sua classe é coesa ou não. E qual a vantagem de ter uma classe coesa? Quanto menos você precisar navegar na sua estrutura de projeto para tratar de um determinado assunto, mais fluente e prática é a manutenção do seu sistema.
Tipos de coesão
Entre os tipos de coesão que podemos citar, temos:
- Acidental: Esse tipo de coesão, como sugerido pelo nome, ocorre sem que seja feito qualquer planejamento. As responsabilidades são agrupadas não de forma projetada, mas sim por conveniência, como, por exemplo, uma classe utilitária com diversas funções não relacionadas a um único assunto;
- Comunicação: Aqui, os elementos são agrupados em função de atualizarem a mesma estrutura de dados ou produzirem os mesmos dados de saída (por exemplo, diversos métodos que geram relatórios correlatos);
- Funcional: Caso os elementos existam no componente para atender a uma mesma função. Para esse tipo de coesão, deve ser possível descrever a função do componente de forma única, mesmo que existam diversos elementos para atender a essa função. Por exemplo, um módulo que possui um conjunto de funções relacionadas entre si para manter os dados de um catálogo de produtos;
- Lógica: Podemos dizer que um módulo possui coesão lógica quando o mesmo realiza funções similares. Considere, por exemplo, um módulo responsável apenas por funções de validação de dados ou tratamento de erros;
- Procedural: Para existir coesão procedural é necessário que os elementos do componente sejam parte de um algoritmo ou procedimento executado em etapas para se chegar a um fim. Por exemplo, o processo de geração de um arquivo, que segue passos como: abrir o arquivo, posicionar um cursor no ponto de escrita, escrever o conteúdo e fechar o arquivo;
- Sequencial: Uma forma semelhante à coesão procedural, com o detalhe de que na coesão sequencial os dados de saída de um elemento do componente são os dados de entrada para um próximo elemento, e assim sucessivamente;
- Temporal: Nesse tipo de coesão, são agrupadas ações realizadas dentro de um mesmo período de tempo. Um exemplo comum para esse tipo de coesão é o agrupamento ...
Quer ler esse conteúdo completo? Tenha acesso completo
Confira outros conteúdos:
Introdução ao JDBC
Novidades do Java
Teste unitário com JUnit
Por Daniel Em 2017Black November
Desconto exclusivo para as primeiras 200 matrículas!
Pagamento anual
12x no cartão
De: R$ 69,00
Por: R$ 54,90
Total: R$ 658,80
Garanta o desconto
- Formação FullStack Completa
- Carreira Front-end I e II, Algoritmo e Javascript, Back-end e Mobile
- +10.000 exercícios gamificados
- +50 projetos reais
- Comunidade com + 200 mil alunos
- Estude pelo Aplicativo (Android e iOS)
- Suporte online
- 12 meses de acesso
Pagamento recorrente
Cobrado mensalmente no cartão
De: R$ 79,00
Por: R$ 54,90 /mês
Total: R$ 658,80
Garanta o desconto
- Formação FullStack Completa
- Carreira Front-end I e II, Algoritmo e Javascript, Back-end e Mobile
- +10.000 exercícios gamificados
- +50 projetos reais
- Comunidade com + 200 mil alunos
- Estude pelo Aplicativo (Android e iOS)
- Suporte online
- Fidelidade de 12 meses
- Não compromete o limite do seu cartão
<Perguntas frequentes>
Nossos casos de sucesso
Eu sabia pouquíssimas coisas de programação antes de começar a estudar com vocês, fui me especializando em várias áreas e ferramentas que tinham na plataforma, e com essa bagagem consegui um estágio logo no início do meu primeiro período na faculdade.
Estudo aqui na Dev desde o meio do ano passado! Nesse período a Dev me ajudou a crescer muito aqui no trampo.
Fui o primeiro desenvolvedor contratado pela minha empresa. Hoje eu lidero um time de desenvolvimento!
Minha meta é continuar estudando e praticando para ser um Full-Stack Dev!Economizei 3 meses para assinar a plataforma e sendo sincero valeu muito a pena, pois a plataforma é bem intuitiva e muuuuito didática a metodologia de ensino. Sinto que estou EVOLUINDO a cada dia. Muito obrigado!
Nossa! Plataforma maravilhosa. To amando o curso de desenvolvimento front-end, tinha coisas que eu ainda não tinha visto. A didática é do jeito que qualquer pessoa consegue aprender. Sério, to apaixonado, adorando demais.
Adquiri o curso de vocês e logo percebi que são os melhores do Brasil. É um passo a passo incrível. Só não aprende quem não quer. Foi o melhor investimento da minha vida!
Foi um dos melhores investimentos que já fiz na vida e tenho aprendido bastante com a plataforma. Vocês estão fazendo parte da minha jornada nesse mundo da programação, irei assinar meu contrato como programador graças a plataforma.
Wanderson Oliveira
Comprei a assinatura tem uma semana, aprendi mais do que 4 meses estudando outros cursos. Exercícios práticos que não tem como não aprender, estão de parabéns!
Obrigado DevMedia, nunca presenciei uma plataforma de ensino tão presente na vida acadêmica de seus alunos, parabéns!
Eduardo Dorneles
Aprendi React na plataforma da DevMedia há cerca de 1 ano e meio... Hoje estou há 1 ano empregado trabalhando 100% com React!
Adauto Junior
Já fiz alguns cursos na área e nenhum é tão bom quanto o de vocês. Estou aprendendo muito, muito obrigado por existirem. Estão de parabéns... Espero um dia conseguir um emprego na área.
Utilizamos cookies para fornecer uma melhor experiência para nossos usuários, consulte nossa política de privacidade.
Aceitar