Até aqui, aprendemos a controlar tempo (assincronicidade) e estado (closures).

Agora vamos aprender a controlar algo ainda mais sutil:

a mudança de dados.

🎯 Objetivo da aula

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

  • Entender o que é imutabilidade
  • Saber por que mutação causa bugs difíceis
  • Trabalhar com dados sem alterá-los
  • Reconhecer padrões imutáveis no JavaScript moderno
  • Escrever código mais previsível

O que é imutabilidade?

Imutabilidade significa:

não alterar um dado existente — criar um novo.

Ou seja:

  • Você não muda o original
  • Você cria uma nova versão

Mutação: o problema silencioso

Veja este exemplo:

 
  const usuario = 
  { 
    nome: "Daniel", idade: 30 
  };
  function fazerAniversario(pessoa) 
  {
    pessoa.idade++;
  }
  fazerAniversario(usuario);
  console.log(usuario.idade); // Saída será 31

O problema aqui não é o resultado.

O problema é:

  • Quem mudou o objeto?
  • Quando mudou?
  • Quem mais depende dele?
Mutação cria efeitos colaterais invisíveis.

Imutabilidade elimina esse problema

Agora a versão imutável:

 
  const usuario = { nome: "Daniel", idade: 30 };
  function fazerAniversario(pessoa) 
  {
    return 
    {
      ...pessoa,
      idade: pessoa.idade + 1
    };
  }
const usuarioAtualizado = fazerAniversario(usuario);
console.log(usuario.idade); // Saída será 30
console.log(usuarioAtualizado.idade); // Saída será 31

Agora:

  • O original permanece intacto
  • A mudança é explícita
  • O fluxo é previsível

Imutabilidade não é “modinha”

Ela resolve problemas reais:

  • Debug mais fácil
  • Menos bugs imprevisíveis
  • Fluxo de dados claro
  • Facilidade de testes
Frameworks modernos dependem disso:

  • React
  • Redux
  • Vue (em vários pontos)
  • Zustand

Arrays e mutação (armadilha comum)

Esses métodos MUTAM o array:

  • push
  • pop
  • splice
  • sort
Eles alteram o array original.

Alternativa imutável

 
  const numeros = [1, 2, 3];
  const novosNumeros = [...numeros, 4];
  console.log(numeros); // Saída: [1, 2, 3]
  console.log(novosNumeros); // Saída: [1, 2, 3, 4]

Map, filter e reduce já são imutáveis

Você já usa imutabilidade sem perceber:

 const pares = numeros.filter(n => n % 2 === 0); 
  • O array original não muda
  • Um novo array é criado

Imutabilidade + Closures = poder

Closures guardam estado.

Imutabilidade garante que esse estado:

  • não seja corrompido
  • não seja alterado inesperadamente
Essa combinação é base de arquiteturas modernas.

Custo da imutabilidade (honestidade)

Imutabilidade:

  • cria novos objetos
  • usa mais memória

Mas:

  • o ganho em previsibilidade compensa
  • otimizações modernas minimizam isso
Imutabilidade é uma escolha consciente, não um dogma.

Resumo da aula para nunca mais esquecer

  • Imutabilidade evita efeitos colaterais
  • Não altere dados — crie novos
  • Mutação dificulta debug
  • JavaScript moderno favorece imutabilidade
  • Previsibilidade vale mais que “economia”

Na próxima aula, vamos dar o próximo passo funcional: Currying.


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?

O personagem Mario surgiu pela primeira vez no mundo dos games em um jogo chamado Donkey Kong, lançado em 1981. Mario, que naquela época se chamava Jumpman, não era o personagem principal do jogo, mas ele se tornaria um dos mais famosos personagens do mundo dos games. 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.


Em 1949 a revista Popular Mechanics fez uma previsão para o futuro, dizendo: "Um dia os computadores pesarão menos do que 1,5 tonelada". E pensar que temos smartphones capazes de realizar milhões de vezes mais operações do que os computadores daquela época.


O épico jogo River Raid, do Atari, foi desenhado e boa parte de sua programação foi feita por uma mulher: Carol Shaw, uma excelente programadora e funcionária da Activision em 1982. Saiba mais sobre a história deste incrível jogo, aqui.


A IBM detém o recorde de patentes em um único ano, atingindo a marca de 4186 registros no ano de 2008. Clique aqui e saiba mais sobre esta gigante do mundo da tecnologia.