Nas aulas anteriores, aprendemos sobre Promises e Try, Catch, Finally e vimos como elas resolvem os problemas dos callbacks, trazendo mais organização ao código assíncrono, além de evitar o travamento da execução do código.

Mas ainda assim, o uso de then e catch pode deixar o código longo e difícil de acompanhar.

Para resolver isso, o JavaScript introduziu async e await, que permitem escrever código assíncrono com cara de código síncrono.

🎯 Objetivo da aula

Ao final desta aula, você será capaz de:

  • Entender o que são async e await
  • Escrever código assíncrono mais legível
  • Substituir then e catch
  • Tratar erros com try e catch
  • Ler código assíncrono como se fosse síncrono

O problema que async/await resolve

Veja um exemplo usando Promises:

 
        buscarDados() .then(dados => 
        { 
          console.log(dados); return processarDados(dados); 
        }) .then(resultado => 
        { 
          console.log(resultado); 
        }) .catch(erro => 
        { 
          console.log(erro); 
        }); 

Funciona, mas a leitura não é tão natural.

Agora veja a mesma lógica usando async e await.

O que significa async?

Quando você coloca async antes de uma função, você está dizendo:

👉 “Essa função trabalha com Promises”.

Toda função async sempre retorna uma Promise, mesmo que você não perceba.

 async function exemplo() { return "Olá"; }
          exemplo().then(resposta => 
          {
            console.log(resposta);
          });
 console.log(resposta); // Saída será "Olá" 

O que significa await?

O await só pode ser usado dentro de funções async.

Ele diz ao JavaScript:

👉 “Espere essa Promise terminar antes de continuar”.

Mas atenção: isso não trava a aplicação.

Primeiro exemplo completo

 
  function buscarDados() 
  { 
    return new Promise(resolve => 
    { 
      setTimeout(() => 
      { 
        resolve("Dados carregados"); 
      }, 2000); 
    }); 
  }
  async function executar() 
  {
    const dados = await buscarDados();
    console.log(dados);
  }
  executar();
 
  console.log(dados); 
  // Saída será "Dados carregados" (após 2 segundos) 

Leia esse código como:

  • Espere buscar os dados
  • Depois, use o resultado

Comparando Promise vs async/await

Com then:

 buscarDados().then(dados => { console.log(dados); }); 

Com async/await:

 const dados = await buscarDados(); console.log(dados); 
async/await não substitui Promises — ele é apenas uma forma mais elegante de usá-las.

Tratando erros com try/catch

Com async/await, tratamos erros usando try e catch.

 
    function falhar() 
    { 
      return Promise.reject("Erro ao carregar dados"); 
    }
    async function executar() 
    {
      try {
        const resultado = await falhar();
        console.log(resultado);
      } 
      catch (erro)
      {
        console.log(erro);
      }
    }
    executar();
 
  console.log(erro); 
  // Saída será "Erro ao carregar dados" 

Código assíncrono que parece síncrono

Esse é o grande poder do async/await:

  • Fluxo mais claro
  • Menos indentação
  • Leitura natural
  • Mais fácil de debugar
Usar await fora de função async causa erro.

Resumo da aula para nunca mais esquecer

  • async define funções assíncronas
  • await espera uma Promise terminar
  • O código fica mais legível
  • Erros são tratados com try/catch
  • É a forma moderna de lidar com assincronicidade

Na próxima aula, vamos entender o que é uma API.


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.

  • Gabinetes

  • Placas-Mãe

  • Processadores

  • Memória

  • Fontes

  • Drives Ópticos

  • Discos Rígidos

  • SSD

  • Placas de Som

  • Placas de Vídeo

Você Sabia?

A Máquina de Pascal, criada em 1642 pelo filósofo, físico e matemático francês Blaise Pascal, é reconhecida como o primeiro computador do mundo e ele foi criado com o objetivo de calcular impostos. Saiba mais.


O mouse foi criado em 9 de dezembro de 1968, por um americano chamado Douglas Engelbart, que o batizou de "XY Position Indicator for a Display System". Conheça a história do mouse clicando aqui.


O jogo Final Fantasy X para o Sony Playstation 2 vendeu, apenas no dia do seu lançamento, 1.455.732 cópias, estabelecendo um recorde de vendagem para as primeiras 24 horas de um game. Méritos da SquareSoft, que desenvolveu um excelente produto!


Considerando todas as adaptações de jogos de videogame para o cinema, a mais bem sucedida foi Lara Croft: Tomb Raider, lançado em 2001 e que faturou 274 milhões de dólares. Ele foi dirigido por Simon West e estrelado pela bela Angelina Jolie.


Utilizar seu notebook em camas, sofás ou qualquer superfície macia pode obstruir as entradas e saídas de ar, elevando a temperatura e provocando danos a diversos componentes. Utilize-o sempre sobre uma superfície rígida. Saiba mais aqui.