Do que se trata o artigo: Neste artigo conheceremos como funciona e como é realizada a implementação de threads e suas principais aplicações em sistemas. Será explicado como utilizar e parametrizar seus principais recursos e como contornar possíveis problemas relacionados à concorrência e ociosidade.
Em que situação o tema útil: Quando há restrições severas de tempo de processamento ou mesmo quando existem rotinas de processamento, o uso de threads pode ser fundamental em um sistema. Neste contexto, realizar mais que uma tarefa ao mesmo tempo, isto é, utilizar o modelo de paralelismo, pode ser muito útil para processar grandes quantidades de informações.
Resumo DevMan: A implementação de threads tem se mostrado uma abordagem interessante quando se trabalha com muitas restrições de processamento. Ela tem o uso mais difundido quando é necessário diminuir o tempo de processamento por meio da estratégia de paralelismo. As threads têm utilização simples, permitindo definir diferentes prioridades de execução e até mesmo equilibrar a ociosidade entre diferentes processos paralelos por meio da comunicação ou sincronismo entre eles. Neste artigo será explicado como criar threads por diferentes maneiras e como configurar suas prioridades de execução. Ainda será explicado a respeito do cuidado com as regiões críticas, onde ocorrem concorrências entre variáveis, e as principais estratégias de solução destas regiões. O sincronismo entre threads, abordado no artigo, ajudará a tornar os processos ainda mais eficientes e cada vez menos ociosos, diminuindo de maneira significativa o tempo de processamento.
Atualmente é cada vez mais exigido que os sistemas demandem menos tempo no cumprimento de suas tarefas. Especialmente os sistemas críticos, pois o tempo de processamento pode ser essencial para que eles funcionem adequadamente. Imagine um sistema de controle de voos cujo processamento demore muito para identificar as aeronaves no radar. Esse atraso pode ser extremamente danoso em alguma situação de emergência. Se os eventos demorarem muito para serem percebidos pelo sistema, será extremamente difícil para um controlador, tomar as medidas necessárias.
Para suprimir a demanda de processamento em curto espaço de tempo são utilizadas várias técnicas e estratégias. Uma delas é o uso de processos paralelos, também conhecidos como threads.
Mas não é somente para lidar com escassez de tempo de processamento que o uso de paralelismo é utilizado. Imagine um robô. Ele pode ter duas funções bem simples, se locomover e identificar obstáculos. Ambas as tarefas precisam funcionar ao mesmo tempo, pois ao se locomover é possível encontrar um obstáculo no caminho e assim alterar sua rota. Esse é um exemplo de paralelismo de atividades diferentes e que precisam ser realizadas em um tempo aceitável, a tempo de tomar as decisões corretas.
Dependendo do tipo de sistema a ser desenvolvido, é possível relacionar estes dois exemplos com aplicações práticas que necessitem de operações paralelas ou demandem menor tempo de processamento.
Imagine que em um sistema de exportação de dados se deseja apresentar ao usuário uma barra de progresso informando o quanto está sendo exportado e o quanto ainda falta. Para resolver esse problema poderíamos ter dois processos paralelos: um para realizar a exportação dos dados e outro processo para mostrar o progresso da operação.
Podemos imaginar ainda outro cenário um pouco mais específico. Um sistema que é utilizado como coletor e sumarizador de dados para posterior visualização. Inicialmente, vamos supor que os dados precisam ser coletados de diversas fontes de dados (por exemplo, três fontes: fonte 1, fonte 2 e fonte 3). Caso seja optado por utilizar a programação convencional (ou sequencial), com um processo apenas, ou monothread, as coletas dos dados seriam realizadas uma após a outra. Se uma coleta durasse em média 2 minutos, para coletar as três fontes seriam necessários 6 minutos. Se os dados têm a necessidade de serem sumarizados para a composição de um indicador em tempo real, como a quantidade de produção de uma determinada peça por minuto, haveria um atraso de no mínimo 6 minutos, considerando as três coletas. Implementando o conceito de processamento simultâneo, ou multithread, seria possível processar as coletas das três fontes de dados ao mesmo tempo e assim este poderia cair de 6 minutos para algo próximo de 2 minutos, tempo de apenas uma coleta, supondo que o tempo gasto pelas coletas sejam semelhantes.
Apesar das vantagens do uso de processamento paralelo, é importante ressaltar que é necessário haver um gerenciamento eficiente destes processos.
Cada processo paralelo, ou seja, cada thread, compartilha as mesmas variáveis globais do sistema. Devido a essa condição é necessário observar se existe ocorrência de condições de disputa entre variáveis. Se uma thread atualiza o valor de uma variável global, caso não haja uma devida sincronização, é possível que outra thread ainda esteja trabalhando com o valor antigo desta mesma variável. Esse tipo de problema de concorrência é conhecido como condição de disputa. Já a região ou o trecho de código onde há a condição de disputa, isto é, onde uma mesma variável pode ser disputada entre um ou mais processos paralelos, é chamado de seção crítica.
Devido à importância do paralelismo para o desenvolvimento de aplicações, este artigo irá explorar como é a implementação de paralelismo por meio do uso de threads, como controlar os diferentes tipos de prioridade de execução, como gerenciar adequadamente a seção crítica e, por fim, explicará como realizar eficazmente a comunicação entre diferentes processos paralelos em um mesmo sistema.
...Confira outros conteúdos:
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.