Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Hello Elixir, entrando na Linguagem Funcional!

Hello Elixir, entrando na Linguagem Funcional!

Imersão sobre o Elixir, linguagem funcional, saindo fora da caixa conforme definiu o nosso amigo Alex Ferreira -https://br.linkedin.com/in/alexsferreira/pt

Opensanca

March 19, 2016
Tweet

More Decks by Opensanca

Other Decks in Programming

Transcript

  1. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos Sistemas Distribuídos
  2. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos Sistemas Distribuídos
  3. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos Sistemas Distribuídos
  4. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web
  5. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web
  6. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web
  7. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web
  8. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web
  9. Guerra dos mundos • Eficiência e confiabilidade • Programação Concorrente

    • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução Sistemas Distribuídos Aplicações Web ?
  10. Que faça-se a luz • Eficiência e confiabilidade • Programação

    Concorrente • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução
  11. Que faça-se a luz • Eficiência e confiabilidade • Programação

    Concorrente • Tolerante a falhas • Suporte à programação de sistemas distribuídos • Fácil Prototipação • Fácil Manutenção • Fácil Evolução
  12. Porque ELIXIR? ”Eu gostei de tudo que vi em Erlang,

    mas eu odiava as coisas que eu não vi” José Valim
  13. Porque ELIXIR? Semântica, Eficiência, Confiabilidade ”Eu gostei de tudo que

    vi em Erlang, mas eu odiava as coisas que eu não vi” José Valim
  14. Porque ELIXIR? Semântica, Eficiência, Confiabilidade Facilidade do Ruby e Experiência

    ”Eu gostei de tudo que vi em Erlang, mas eu odiava as coisas que eu não vi” José Valim
  15. Porque ELIXIR? Semântica, Eficiência, Confiabilidade Ferramentas e Modularidade Facilidade do

    Ruby e Experiência ”Eu gostei de tudo que vi em Erlang, mas eu odiava as coisas que eu não vi” José Valim
  16. Porque ELIXIR? Semântica, Eficiência, Confiabilidade Ferramentas e Modularidade Facilidade do

    Ruby e Experiência ”Eu gostei de tudo que vi em Erlang, mas eu odiava as coisas que eu não vi” José Valim Macros
  17. Elixir é uma linguagem dinâmica e funcional projetada para construir

    aplicações escaláveis e de fácil manutenção.
  18. Comparativo 1 2 3 4 5 -module(hello_world). -compile(export_all). say_hello(Name) →

    io:print(“Hello ~p~n”, [Name]). Há quem diga que o problema é a linguagem ser funcional, outros que reclamam do suporte a testes, outros da nomenclatura utilizada, outros da falta de ferramentas e etc.
  19. Comparativo 1 2 3 4 5 defmodule HelloWorld do def

    say_hello(name) do IO.puts “Hello #{name}” end end A estrutura é simples e muito familiar para quem já lê código Ruby.
  20. Tipos Básicos Os tipos básicos do elixir são: integer, floats,

    booleans, atoms, strings, lists e tuples 1 #inteiro 0x1f #inteiro 1.0 #float True #boolean :atom #atom / symbol ”elixir” #string [9,8,7,6] #list {5,6,7,8} #tuple
  21. Tipos Básicos - Inteiros Elixir também suporta a conversão de

    números binários, octais e hexadecimais para inteiros:
  22. Tipos Básicos - Float O pontos flutuantes necessitam de um

    ponto, seguindo por, pelo menos um dígito; estes possuem uma precisão de 64 bits e suportam e para números exponenciais.
  23. Tipos Básicos - Float Você pode chamar a função round

    para obter o número inteiro mais próximo, ou a função trunc para obter a parte inteira de um float.
  24. Tipos Básicos – Booleans Elixir suporta true e false como

    valores booleanos; todo valor é verdadeiro com excessão de false e nil:
  25. Tipos Básicos – Atoms Átomos são constantes, onde seu nome

    é o seu próprio valor. Algumas outras linguagens chamam estes símbolos:
  26. Tipos Básicos - String As strings em Elixir são codificadas

    em utf-8 e são representadas com aspas duplas, suporta quebras de linhas, caracteres de escape e interpolação.
  27. Tipos Básicos - Lists As listas são simples coleções de

    valores, elas podem incluir múltiplos tipos; listas podem incluir valores não-exclusivos: Elixir implementa listas como listas encadeadas. Isso significa que acessar a profundidade da lista é uma operação O(n).
  28. Tipos Básicos – Lists - Concatenando e Subtraindo A concatenação

    de listas usa o operador ++/2 O suportare para subtração é provido pelo operador --/2. É seguro subtrair um valor que não existe, isso não retorna um erro.
  29. Tipos Básicos – Lists – Cabeça e Cauda Quando usamos

    listas é comum trabalhar com a cabeça e a cauda da lista. O Elixir provê funções úteis para trabalhar com essas partes, são elas hd e tl A cabeça é o primeiro elemento da lista e a cauda são os elementos restantes.
  30. Tipos Básicos – Lists – Cabeça e Cauda Vamos atribuir

    uma lista para uma variável e recuperar a sua cabeça e a cauda:
  31. Tipos Básicos – Lists – Cabeça e Cauda Além das

    funções citadas, podemos utilizar o o operador pipe |;
  32. Tipos Básicos – Tuples O Elixir usa chaves para definir

    tuples, assim como as listas as tuples podem conter qualquer valor.
  33. Tipos Básicos – Tuples As tuples são armazenadas de forma

    contígua na memória. Permitindo o acesso a sua profundidade de forma rápida.
  34. Tipos Básicos – Tuples Também é possível modificar um elemento

    em um índice especifico usando a função put_elem
  35. Controle de Fluxo – case O case nos permite comparar

    um valor contra muitos padrões até encontrarmos um que corresponda
  36. Controle de Fluxo – case O uso da variável _

    é uma importante inclusão na declaração do case.
  37. Controle de Fluxo – case Considere o _ como o

    else que irá igualar com todo o resto
  38. Controle de Fluxo – case Se você pretende encontrar correspondência

    em variáveis existentes, você precisará do operador ^
  39. Controle de Fluxo – cond Em muitas circunstâncias, queremos verificar

    condições diferentes e encontrar o primeiro resultado correspondente. Em tais casos recorremos ao cond
  40. Controle de Fluxo – cond Se nenhuma das condições corresponder

    será gerado um erro assim como no case. Por esta razão, pode ser necessário adicionar uma condição final
  41. Controle de Fluxo – if e unless No Elixir o

    if e unless são definidos como macros, não construtores de linguagem.
  42. Controle de Fluxo – if e unless O unless é

    bem parecido ao uso do if porém trabalhando de forma negativa
  43. Módulos – Funções Nomeadas Dentro de um módulo, podemos definir

    funcões com def e funções privadas com defp.
  44. Conhecendo o MIX Se você estiver familiarizado com Ryby, o

    mix é o Bundler, RubyGems e o Rake juntos.
  45. Conhecendo o MIX – Criando novos projetos O mix faz

    com que a crianção do projeto seja facil utilizando o comando mix new
  46. Conhecendo o MIX – Gegenciando Dependencias Uma vez que definimos

    nossas dependencias Usaremos o comando abaixo para instalar as dependencias.
  47. Exercicio – Somando Lista Criar modulo MyList, com métodos sum

    • Deverá passar uma lista para o método do modulo retornando o valor total
  48. Exercicio – Calculadora Criar modulo Calculator, com método result. A

    calculadora deve executar as seguintes operações • Somar • Subtrair • Multiplicar • Dividir • Checar se a opração é valida • Deve-se utilizar o tuple para calcular, ex: {:soma, 1, 2}
  49. Exercicio – FizzBuzz Criar modulo FizzBuzz, com métodos parse e

    create • Números divisíveis por 3 devem ser substituidos por Fizz • Números divisíveis por 5 devem ser substituidos por Buzz • Números divisíveis por 3 e 5 devem ser substituidos por FizzBuzz
  50. Sintaxe agora não é mais desculpa! Nem o ferramental, nem

    a comunidade, nem a disponibilidade de bibliotecas e etc, etc, etc. Sejam Bem-vindos ao mundo dos alquimistas!