VAGAS DE EMPREGO

balta.io balta.io
  • Cursos
  • Carreiras
  • Para sua Empresa
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog

Seja Premium
balta.io

  • Cursos
  • Carreiras
  • Para sua Empresa
  • Agenda
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog
  • Player
Seja Premium

Entre ou Cadastre-se

  • Home
  • Artigos
  • Inversion of Control


👉 Temos uma versão mais atualizada deste artigo no nosso novo Blog

Inversion of Control

IoC é um princípio de design que prega uma melhor plugabilidade, testabilidade, usabilidade e baixo acoplamento.

Inversion of Control

IoC ou inversão de controle (Inversion of Control) é um princípio de software que inverte o fluxo de controle em comparação a outros fluxos tradicionais como por exemplo a programação procedural.

No IoC, os pedaços de software que criamos recebem o fluxo e não ao contrário. Então, enquanto a programação procedural por exemplo, expressa diretamente o precisa ser feito, no IoC nós delegamos para libs externas.

Princípio Hollywoodiano

Este conceito também é conhecido Princípio Hollywoodano que diz o seguinte: "Não nos chame, nós chamamos você".

Esta brincadeira, reflete diretamente o que gostaríamos de ter em nosso código, pequenos pedaços, que agem de form independente e podem ser utilizados em diversas partes do nosso código. Estes pedaços não "chamam" nosso código... nós chamamos eles, quando precisamos deles.

História

Inversion of Control ou IoC é utilizada para aumentar a modularidade dos sistemas, criar extensibilidade e usufruir melhor da OOP (Programação Orientada a Objetos). O termo inicial foi utilizado por Michael Mattson mas ficou popular em 2004 após citado por Martin Fowler e Robert C. Martin (Uncle Bob).

Inversion of Control e Dependency Injection

Embora esteja relacionado com DI (Dependency Injection -- Injeção de Dependência) e DIP (Dependency Inversion Principle -- Princípio da inversão de dependência), o IoC (Inversion of Control) se difere de ambos.

DI é a técnica que utilizamos para alcançar o IoC e DIP provê um maior desacoplamento entre as camadas visando depender mais de abstrações do que de implementações.

Inversion of Control na prática

Para entender melhor este princípio, vamos tomar como base o código abaixo, que por algum motivo precisa recuperar o cliente do banco e faz esta chamada de forma direta.

public class OrderController : Controller
{
    [Route("v1/orders")]
    [HttpPost]
    public async Task<string> Place(PlaceOrderCommand command)
    {
        // #1 - Recupera o cliente
        Customer customer = null;
        using (var conn = new SqlConnection("CONN_STRING"))
        {
            const query = "SELECT * FROM CUSTOMER WHERE ID=@id";
            customer = conn.Query<Customer>
                (query, new { id = command.CustomerId })
                .FirstOrDefault();
        }
        ...
    }

Dominando Injeção de Dependência

Se notarmos, este código está acoplado o que significa que não podemos reutilizar esta pesquisa por cliente em nenhum outro ponto do sistema. A manutenção também é difícil neste momento, pois precisamos lembrar de alterar todo lugar onde este código é chamado, e para finalizar a visibilidade é ruim, já que tem muita coisa para se preocupar acontecendo no momento.

A solução é externalizar este código e chamá-lo apenas quando precisamos. Desta forma temos um pedaço pequeno, reusável, fácil de ler, fácil de testar e de dar manutenção.

public class CustomerRepository
{
    public async Task<Customer?> GetByIdAsync(Guid id)
    {
        var using (var conn = new SqlConnection("CONN_STRING"))
        const query = "SELECT * FROM CUSTOMER WHERE ID=@id";
        return customer = conn.FirstOrDefaultAsync<Customer>(query, new { id = Id });
    }
}

Com o código separado, podemos fazer uso do Dependency Injection (Injeção de dependência) para desacoplar o código do controlador.

public class OrderController : Controller
{
    private readonly CustomerRepository _repository;

    public OrderController(CustomerRepository repository)
        => _repository = repository;

    [Route("v1/orders")]
    [HttpPost]
    public async Task<string> Place(PlaceOrderCommand command)
    {
        // #1 - Recupera o cliente
        var customer = await _repository.GetByIdAsync(command.CustomerId);
        ...
    }

Note que agora temos uma dependência do CustomerRepository, ou seja, não conseguimos criar uma instância do OrderController sem informar um CustomerRepository.

Dependency Injection no .NET

Como resultado, precisamos resolver estas dependências para poder executar nosso código e o .NET possui uma implementação para isto, que também chamamos de Service Locator.

builder.Services.AddTransient<CustomerRepository>();

Vale lembrar que o .NET possúi vários métodos para gerenciar o ciclo de vida dos objetos, como AddScoped e AddSingleton

Dependency Inversion

Neste cenário, o DIP se encaixaria criando um desacoplamento ainda maior entre o controlador e o reposiório, por meio de interfaces (Abstrações).

public class OrderController : Controller
{
    private readonly ICustomerRepository _repository;

    public OrderController(ICustomerRepository repository)
        => _repository = repository;

    [Route("v1/orders")]
    [HttpPost]
    public async Task<string> Place(PlaceOrderCommand command)
    {
        // #1 - Recupera o cliente
        var customer = await _repository.GetByIdAsync(command.CustomerId);
        ...
    }
builder.Services.AddTransient<ICustomerRepository, CustomerRepository>();

Conclusão

IoC, DI e DIP são termos comumente visto juntos, mas que tem finalidades diferentes como pudemos ver. Enquanto um é a técnica, os outros são princípios de design que pregam obter um baixo acoplamento.

Fontes

  • WikiPedia
  • Artigo: Dependency Inversion

Populares

Priority Queue

Priority Queue ou fila prioritária é um tipo de lista inclusa no C# 10 que permite que seus itens...


Implicit Operators no C#

Implicit Operators permitem adicionar comportamentos de conversão a objetos Built In ou complexos...


ASP.NET 5 – Autenticação e Autorização com Bearer e JWT

Este artigo atualmente utiliza a versão 5.0.0-rc.1 do ASP.NET/.NET, o que significa que ainda não...


Clean Code - Guia e Exemplos

Saiba como manter seu código limpo (Clean Code) seguindo algumas práticas sugeridas pelo Robert C...


Git e GitHub - Instalação, Configuração e Primeiros Passos

Git é um sistema de controle de versões distribuídas, enquanto GitHub é uma plataforma que tem o ...


Compartilhe este artigo



Conheça o autor

André Baltieri

André Baltieri

Microsoft MVP

Me dedico ao desenvolvimento de software desde 2003, sendo minha maior especialidade o Desenvolvimento Web. Durante esta jornada pude trabalhar presencialmente aqui no Brasil e Estados Unidos, atender remotamente times da ?ndia, Inglaterra e Holanda, receber 8x Microsoft MVP e realizar diversas consultorias em empresas e projetos de todos os tamanhos.





3.133

Aulas disponíveis

292

horas de conteúdo

76.401

Alunos matriculados

52.960

Certificados emitidos





Comece de graça agora mesmo!

Temos mais de 21 cursos totalmente de graça e todos com certificado de conclusão.

Começar


Prefere algo mais Premium?

Conheça nossos planos



Premium anual

Compra única, parcelada em até
12x no cartão de crédito


12x R$

99

,79

=R$ 1.197,44
  • 1 ano de acesso
  • Acesso à todo conteúdo
  • Emissão de Certificado
  • Tira Dúvidas Online
  • 67 cursos disponíveis
  • 10 carreiras disponíveis
  • 161 temas de tecnologia
  • Conteúdo novo todo mês
  • Encontros Premium

Começar agora

Política de privacidade



Precisa de ajuda?

Dúvidas frequentes



  • Posso começar de graça?

    Sim! Basta criar sua conta gratuita no balta.io e começar seus estudos. Nós contamos com diversos cursos TOTALMENTE gratuitos e com certificado de conclusão.

  • Vou ter que pagar algo?

    Nós temos cursos gratuitos e pagos, porém você não precisa informar nenhum dado de pagamento para começar seus estudos gratuitamente conosco. Os cursos gratuitos são completos e com certificado de conclusão, você não paga nada por eles.

    Porém, caso queira algo mais Premium , você terá acesso à diversos benefícios que vão te ajudar ainda mais em sua carreira.

  • Por onde devo começar?

    Siga SEMPRE as nossas Carreiras , elas vão te orientar em todos os sentidos. Os cursos já estão organizados em categorias e carreiras para facilitar seu aprendizado.
    Nossa sugestão para aprendizado é começar pelo Backend e seguindo para Frontend e Mobile.

    • Backend
    • Frontend
    • Mobile

  • Os cursos ensinam tudo que preciso?

    Nenhum curso no mundo vai te ensinar tudo, desculpa ser sincero! Os cursos são uma base, eles fornecem por volta de 30% do que você precisa aprender, o resto é com você, com dedicação e MUITA prática.

  • O que eu devo estudar?

    Java ou .NET? Angular ou React? Xamarin ou Flutter? A resposta é simples e direta: "Você já sabe o básico?"

    Se você ainda não sabe BEM o básico, ou seja, os fundamentos, OOP, SOLID, Clean Code, está perdendo tempo estudando Frameworks ou até coisas mais avançadas como Docker. Foque nos seus objetivos primeiro.
    Agora se você está indeciso sobre qual Framework estudar, a boa notícia é que o mercado neste momento está bem aquecido e você tem várias oportunidade. Desta forma o que levaríamos em conta para tomar esta decisão seria:

    • Já sei o básico
    • O Framework/Tecnologia tem mercado onde eu estou (região)
    • O Framework/Tecnologia é utilizado em uma empresa onde quero atual
    • O Framework/Tecnologia resolve meu problema
    • Eu gosto de utilizar o Framework/Tecnologia

  • Estou pronto para estudar no balta.io?

    Com certeza! O primeiro passo é começar e você pode fazer isto agora mesmo!

    Começar de graça

Ainda tem dúvidas?





Assine nosso Newsletter

Receba em primeira mão todas as nossas novidades.

Cadastrar


balta.io

Sobre

  • Como funciona?
  • Seja Premium
  • Agenda
  • Blog
  • Todos os cursos

Cursos

  • Frontend
  • Backend
  • Mobile
  • Fullstack

Suporte

  • Termos de uso
  • Privacidade
  • Cancelamento
  • Central de ajuda

Redes Sociais

  • Telegram
  • Facebook
  • Instagram
  • YouTube
  • Twitch
  • LinkedIn
  • Discord