Stay informed and never miss an Core update!
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.
Vamos falar sobre paralelismo e concorrência de um jeito bem tranquilo e com exemplos breves, fazendo algumas comparações pra ficar mais fácil de entender. Imagina que você tem uma cozinha e precisa fazer um monte de coisas: cozinhar, lavar a louça, cortar os legumes, etc. Como é que você organiza tudo isso? Bem, é aí que entram essas duas ideias.
Primeiro, pensa na concorrência como se você fosse um chefe multitarefas, fazendo tudo ao mesmo tempo, mas com uma limitação: você só tem duas mãos! Então, você começa a cortar os legumes, aí para um pouquinho, vai mexer na panela, depois volta a cortar os legumes, e assim vai. Você não está fazendo várias coisas ao mesmo tempo, mas está alternando entre elas, rapidinho, como se fosse uma dança bem coordenada.
A grande sacada da concorrência é essa alternância rápida. No mundo dos computadores, isso acontece com o processador. Ele só consegue lidar com uma tarefa de cada vez, mas é tão rápido que parece que tudo está rolando ao mesmo tempo. Isso é a concorrência: várias tarefas sendo feitas quase ao mesmo tempo, alternando o tempo de execução, mas com um único "chefe" (o processador) coordenando tudo.
Agora, pensa no paralelismo como se você tivesse vários chefs na cozinha, cada um com uma função específica. Um corta os legumes, outro mexe na panela, outro lava a louça, tudo rolando ao mesmo tempo de verdade. No computador, isso acontece quando você tem vários núcleos (cores) no processador, cada um lidando com uma tarefa diferente. Aí sim, as tarefas estão realmente sendo executadas em paralelo.
Então, se você tem 4 núcleos no processador, você pode ter até 4 tarefas sendo processadas ao mesmo tempo. Não é mais uma questão de alternar tarefas rapidamente como na concorrência. Cada núcleo pega uma tarefa e manda ver.
Agora você deve estar pensando: "Tá, mas qual a diferença na prática?" Bom, a concorrência é legal quando você tem um monte de tarefas que não são super pesadas. Como seu cérebro alternando entre as atividades, você consegue lidar com muita coisa "ao mesmo tempo" sem se perder. Isso é o que muitos sistemas fazem com tarefas leves, tipo rodar aplicativos no celular.
Já o paralelismo é mais útil quando você precisa de potência bruta, tipo processar gráficos de jogos ou rodar simulações pesadas. Nesses casos, você quer mais de um cérebro (núcleo) trabalhando de verdade ao mesmo tempo.
Se a concorrência fosse um show de malabares, o malabarista só tem duas mãos, mas consegue jogar várias bolas no ar. Ele pega uma, joga pro alto, pega outra, joga também, e assim por diante. Não tem várias bolas nas mãos dele ao mesmo tempo, mas parece que está fazendo tudo junto.
Já o paralelismo seria como se você tivesse vários malabaristas, cada um cuidando de suas próprias bolas. Nesse caso, sim, várias bolas estão no ar ao mesmo tempo porque cada um está realmente fazendo a sua parte sem precisar alternar.
O truque é saber quando usar um ou outro. Às vezes, a concorrência pode ser até mais eficiente, principalmente quando você tem um monte de tarefas que precisam esperar por alguma coisa, como um download ou uma resposta de um servidor. Enquanto uma tarefa espera, o processador alterna pra outra que pode ser feita naquele momento.
Já o paralelismo é mais poderoso quando você pode dividir o trabalho pesado em pedaços menores que podem ser feitos simultaneamente. Aí sim, você ganha velocidade e eficiência.
Agora, para ilustrar isso, vou gerar algumas imagens que podem ajudar a entender essas ideias visuais.
Vou criar uma imagem para representar essas duas ideias!
Aqui está a imagem comparando concorrência e paralelismo na cozinha! Espero que a visualização ajude a entender essas ideias de uma maneira simples.