Na aula anterior, aprendemos que o JavaScript possui duas filas principais para tarefas assíncronas:
- Microtask Queue
- Macrotask Queue
Agora chegou a hora de ver isso acontecendo com exemplos reais, exatamente como você encontra no dia a dia.
🎯 Objetivo da aula
Ao final desta aula, você será capaz de:
- Identificar microtasks e macrotasks no código
- Prever a ordem de execução no console
- Entender como Promises, timeouts e eventos interagem
- Evitar bugs causados por ordem inesperada de execução
Exemplo 1 — Promise vs setTimeout
Esse é o exemplo mais clássico — e mais importante.
console.log("Início");
setTimeout(() =>
{
console.log("Macrotask");
}, 0);
Promise.resolve().then(() =>
{
console.log("Microtask");
});
console.log("Fim");
Antes de rodar, tente prever a ordem.
console.log("Início"); // Saída: Início
console.log("Fim");
// Saída: Fim
// Microtasks primeiro
// Saída: Microtask
// Depois as macrotasks
// Saída: Macrotask
Exemplo 2 — Várias Promises encadeadas
Todas as Promises resolvidas entram na Microtask Queue.
console.log("Início");
Promise.resolve()
.then(() =>
{
console.log("Microtask 1");
})
.then(() =>
{
console.log("Microtask 2");
});
console.log("Fim");
console.log("Início"); // Saída: Início
console.log("Fim");
// Saída: Fim
// Microtasks executam em sequência
// Saída: Microtask 1
// Saída: Microtask 2
Exemplo 3 — setTimeout dentro de Promise
Aqui vemos microtasks criando macrotasks.
Promise.resolve().then(() =>
{
console.log("Microtask");
setTimeout(() =>
{
console.log("Macrotask criada pela microtask");
}, 0);
});
Promise.resolve().then(() =>
{
console.log("Microtask");
}); // Saída: Microtask
// Depois que a microtask termina
// Saída: Macrotask criada pela microtask
Exemplo 4 — Evento de clique (macrotask)
Eventos do DOM entram como macrotasks.
button.addEventListener("click", () =>
{
console.log("Clique");
Promise.resolve().then(() =>
{
console.log("Microtask do clique");
});
});
Ao clicar no botão:
console.log("Clique"); // Saída: Clique
console.log("Microtask do clique");
// Saída: Microtask do clique
Exemplo 5 — Armadilha comum
Misturar muitos then pode gerar comportamentos inesperados.
setTimeout(() =>
{
console.log("Timeout");
Promise.resolve().then(() =>
{
console.log("Microtask dentro do timeout");
});
}, 0);
setTimeout(() =>
{
console.log("Timeout"); });
// Saída: Timeout
// Microtask criada depois
// Saída: Microtask dentro do timeout
Regra prática para o dia a dia
- Código síncrono roda primeiro
- Depois, todas as microtasks
- Por último, uma macrotask por vez
Resumo da aula para nunca mais esquecer
- Microtasks têm prioridade máxima
- Promises usam microtasks
- setTimeout e eventos usam macrotasks
- O Event Loop sempre esvazia microtasks primeiro
- A ordem do console pode ser prevista
Na próxima aula, vamos aplicar esse conhecimento para entender profundamente Promises e async/await, sem mistério e sem “decorar”.
HARDWARE
Entendendo o seu computador
O que há dentro do meu computador?
Existem alguns componentes fundamentais presentes dentro do seu computador e é muito importante que você conheça um pouco sobre eles, seja para argumentar com algum vendedor durante a compra de um novo PC ou para identificar alguma atitude desleal de algum técnico que esteja te passando um orçamento para reparo. Na seção Raio-X aqui do Contém Bits você pode conhecer e entender mais detalhadamente sobre cada componente, ou também pode clicar abaixo no componente que deseja, para conhecê-lo melhor.
Você Sabia?
Ultima Online
Criar um jogo é muito mais complexo do que parece. São milhares, às vezes, milhões de linhas de código. Isso não é exagero! Apenas o jogo Ultima Online possui 6.006.313 linhas de programação, totalizando 25.103.295 palavras
Tetris
O título Tetris detém o recorde de jogo mais adaptado de todos os tempos. No total foram mais de 60 plataformas diferentes que receberam alguma versão do quebra-cabeças criado por Alexey Pajitnov. Conheça mais sobre este incrível jogo clicando aqui.
Asteroids
O título Asteroids, do Atari, possui recorde de pontuação há 30 anos. Em 1982 um americano chamado Scott Safran atingiu a marca de 41.336.440. Atualmente ele faz parte de um minúsculo grupo de jogadores que conseguiram manter seus recordes por mais de 30 anos.
Civilization
A empresa Take-Two pagou à Infogrames mais de 22 milhões de dólares pelos direitos de Civilization, em novembro de 1994. Ainda sobre este título, Sid Meier, um dos seus fundadores, é o profissional da área dos games mais premiado em todo o mundo.
Senhas
Digitar senhas em computadores de uso coletivo é extremamente perigoso, pois além de softwares de monitoramento, existem dispositivos de hardware que podem capturar suas senhas. Evite ao máximo acessar sites de bancos a partir destes computadores. Veja mais aqui.










