2013-08-13 02:31:46 +00:00
---
contributors:
- ["Bruno Henrique - Garu", "http://garulab.com"]
2015-10-24 22:51:42 +00:00
- ["Jean Matheus Souto", "http://jeanmatheussouto.github.io"]
2013-09-09 05:05:15 +00:00
translators:
2013-08-14 16:34:10 +00:00
- ["Katyanna Moura", "https://twitter.com/amelie_kn"]
2016-10-27 08:13:37 +00:00
- ["Alan Peterson Carvalho Silva", "https://twitter.com/DemonKart"]
2013-08-13 02:31:46 +00:00
---
```ruby
2013-08-14 16:20:47 +00:00
# Isso é um comentário
2013-08-13 02:31:46 +00:00
=begin
2013-08-14 14:56:14 +00:00
Isso é um comentário multilinha
2013-08-13 02:31:46 +00:00
Ninguém os usa
2013-08-14 14:56:14 +00:00
Você não deve usar também
2013-08-13 02:31:46 +00:00
=end
# Primeiro e principal: Tudo é um objeto.
# Números são objetos
3.class #=> Fixnum
3.to_s #=> "3"
2013-08-14 14:56:14 +00:00
# Um pouco de aritmética básica
2013-08-13 02:31:46 +00:00
1 + 1 #=> 2
8 - 1 #=> 7
10 * 2 #=> 20
35 / 5 #=> 7
2014-11-25 23:02:54 +00:00
# Aritmética é apenas açúcar sintático
2013-08-14 15:52:39 +00:00
# para chamar um método de um objeto
2013-08-13 02:31:46 +00:00
1.+(3) #=> 4
2013-08-14 16:34:10 +00:00
10.* 5 #=> 50
2013-08-13 02:31:46 +00:00
2013-08-14 15:52:39 +00:00
# Valores especiais são objetos
2013-08-13 02:31:46 +00:00
nil # Nada para ver aqui
true # verdadeiro
false # falso
nil.class #=> NilClass
true.class #=> TrueClass
false.class #=> FalseClass
# Igualdade
1 == 1 #=> true
2 == 1 #=> false
# Desigualdade
1 != 1 #=> false
2 != 1 #=> true
!true #=> false
!false #=> true
# além de 'false', 'nil' é o único outro valor falso
!nil #=> true
!false #=> true
!0 #=> false
# Mais comparações
1 < 10 # = > true
1 > 10 #=> false
2 < = 2 #=> true
2 >= 2 #=> true
2018-10-31 11:37:56 +00:00
# Strings são objetos
2013-08-13 02:31:46 +00:00
'Eu sou uma string'.class #=> String
"Eu também sou uma string".class #=> String
placeholder = "usar interpolação de string"
"Eu posso #{placeholder} quando estiver usando aspas duplas"
#=> "Eu posso usar insterpolação de string quando estiver usando aspas duplas"
2013-08-14 14:56:14 +00:00
# imprime para output (saída)
2013-08-13 02:31:46 +00:00
puts "Estou imprimindo"
# Variáveis
x = 25 #=> 25
x #=> 25
# Note que uma atribuição retorna o valor atribuido
2013-08-14 14:56:14 +00:00
# Isso significa que você pode fazer múltiplas atribuições:
2013-08-13 02:31:46 +00:00
x = y = 10 #=> 10
x #=> 10
y #=> 10
# Por convenção, use snake_case para nomes de variáveis
snake_case = true
2013-08-14 15:52:39 +00:00
# Use nomes de variáveis descritivos
2013-08-13 02:31:46 +00:00
caminho_para_a_raiz_do_projeto = '/bom/nome/'
caminho = '/nome/ruim/'
2013-08-14 15:52:39 +00:00
# Símbolos (são objetos)
2016-06-26 13:05:04 +00:00
# Símbolos são imutáveis, são constantes reutilizáveis representados
2013-08-16 16:44:22 +00:00
# internamente por um valor inteiro. Eles são frequentemente usados no
# lugar de strings para transmitir com eficiência os valores específicos
# e significativos
2013-08-13 02:31:46 +00:00
:pendente.class #=> Symbol
status = :pendente
status == :pendente #=> true
status == 'pendente' #=> false
status == :aprovado #=> false
# Arrays
# Isso é um array
[1, 2, 3, 4, 5] #=> [1, 2, 3, 4, 5]
# Arrays podem conter diferentes tipos de itens
array = [1, "Oi", false] #=> => [1, "Oi", false]
# Arrays podem ser indexados
# a partir do começo
array[0] #=> 1
array[12] #=> nil
2014-11-25 23:02:54 +00:00
# Como aritmética, o acesso via [var]
2013-08-13 02:31:46 +00:00
# é apenas açúcar sintático
# para chamar o método [] de um objeto
array.[] 0 #=> 1
array.[] 12 #=> nil
# a partir do final
array[-1] #=> 5
2013-08-14 16:34:10 +00:00
# Com um índice de começo e fim
2013-08-13 02:31:46 +00:00
array[2, 4] #=> [3, 4, 5]
# Ou com um intervalo de valores
array[1..3] #=> [2, 3, 4]
# Adicionar a um array como este
array < < 6 # = > [1, 2, 3, 4, 5, 6]
2013-08-14 14:56:14 +00:00
# Hashes são o principal dicionário de Ruby com pares de chaves(keys)/valor(value).
2013-08-13 02:31:46 +00:00
# Hashes são simbolizados com chaves "{}"
hash = {'cor' => 'verde', 'numero' => 5}
hash.keys #=> ['cor', 'numero']
2013-08-14 15:52:39 +00:00
# Hashes podem ser rapidamente pesquisados pela chave (key)
2013-08-13 02:31:46 +00:00
hash['cor'] #=> 'verde'
hash['numero'] #=> 5
# Procurar em um hash por uma chave que não existe retorna nil:
hash['nada aqui'] #=> nil
# Interar sobre hashes com o método #each:
hash.each do |k, v|
puts "#{k} é #{v}"
end
2013-08-14 15:52:39 +00:00
# Desde o Ruby 1.9, temos uma sintaxe especial quando usamos símbolos como chaves (keys)
2013-08-13 02:31:46 +00:00
2014-11-25 23:02:54 +00:00
novo_hash = {defcon: 3, acao: true}
2013-08-13 02:31:46 +00:00
novo_hash.keys #=> [:defcon, :acao]
2013-08-14 15:52:39 +00:00
# Dica: Tanto Arrays quanto Hashes são Enumerable.
2013-08-13 02:31:46 +00:00
# Eles compartilham um monte de métodos úteis como each, map, count e mais
# Estruturas de controle
if true
"Se verdadeiro"
elsif false
2014-11-25 23:02:54 +00:00
"else if, opcional"
2013-08-13 02:31:46 +00:00
else
2014-11-25 23:02:54 +00:00
"else, também é opcional"
2013-08-13 02:31:46 +00:00
end
for contador in 1..5
puts "interação #{contador}"
end
#=> contador 1
#=> contador 2
#=> contador 3
#=> contador 4
#=> contador 5
# PORÉM
# Ninguém usa para loops
# Use "each" em vez, dessa forma:
(1..5).each do |contador|
puts "interação #{contador}"
end
#=> contador 1
#=> contador 2
#=> contador 3
#=> contador 4
#=> contador 5
contador = 1
while contador < = 5 do
puts "interação #{contador}"
contador += 1
end
#=> contador 1
#=> contador 2
#=> contador 3
#=> contador 4
#=> contador 5
grau = 'B'
case grau
when 'A'
2013-08-14 16:20:47 +00:00
puts "Um longo caminho a percorrer, pequeno gafanhoto"
2013-08-13 02:31:46 +00:00
when 'B'
puts "Melhor sorte da próxima vez"
when 'C'
puts "Você pode fazer melhor"
when 'D'
puts "Scraping through"
when 'F'
puts "Você falhou"
2013-08-14 16:34:10 +00:00
else
2013-08-13 02:31:46 +00:00
puts "Alternative grading system, eh?"
end
# Funções
def dobrar(x)
x * 2
end
# Funções (e todos os blocos) retornam implicitamente o valor da última linha
dobrar(2) #=> 4
# Parênteses são opicionais onde o resultado é claro
dobrar 3 #=> 6
dobrar dobrar 3 #=> 12
def somar(x,y)
x + y
end
2013-08-14 15:52:39 +00:00
# Argumentos de métodos são separados por uma vírgula
2013-08-13 02:31:46 +00:00
somar 3, 4 #=> 7
2014-11-25 23:02:54 +00:00
somar(3,4), 5 #=> 12
2013-08-13 02:31:46 +00:00
# yield
2016-06-26 13:05:04 +00:00
# Todos os métodos possuem implicitamente um paramêtro opcional que é um bloco
2013-08-13 02:31:46 +00:00
# ele pode ser chamado com a palavra chave 'yield'
def ao_redor
puts "{"
yield
puts "}"
end
ao_redor { puts 'Olá mundo' }
# {
# Olá mundo
# }
# Define uma classe com a palavra chave 'class'
class Humano
2013-08-14 16:20:47 +00:00
# Uma variável de classe. Ela é compartilhada por todas as instâncias dessa classe
2013-08-13 02:31:46 +00:00
@@especies = "H. sapiens"
# Inicialização básica (contructor)
def initialize(nome, idade=0)
2016-06-26 13:05:04 +00:00
# Atribui o argumento para a variável de instância "nome" do objeto
2013-08-13 02:31:46 +00:00
@nome = nome
# Se a idade não for passada, nós definimos um valor padrão na lista de argumentos
@idade = idade
end
# Método básico para atribuir valor
def nome=(nome)
@nome = nome
end
# Método básico de resgatar valor
def nome
@nome
end
2016-06-26 13:05:04 +00:00
# Um método de classe usa a palavra chave self para se diferenciar dos métodos de instância.
2013-08-13 02:31:46 +00:00
# Ele só pode ser chamado na classe, não na instancia
def self.diz(msg)
puts "#{msg}"
end
def especies
@@especies
end
end
2013-08-14 15:52:39 +00:00
# Instanciando uma classe
2013-08-13 02:31:46 +00:00
jim = Humano.new("Jim Halpert")
dwight = Humano.new("Dwight K. Schrute")
# Vamos chamar um par de métodos
jim.especies #=> "H. sapiens"
jim.nome #=> "Jim Halpert"
jim.nome = "Jim Halpert II" #=> "Jim Halpert II"
jim.nome #=> "Jim Halpert II"
dwight.especies #=> "H. sapiens"
dwight.nome #=> "Dwight K. Schrute"
# Chamar o método de classe
Humano.diz("Oi") #=> "Oi"
2013-08-14 14:56:14 +00:00
# Uma classe também é objeto em Ruby. Então uma classe pode possuir variável de instância
# Variáveis de classe são compartilhadas entre a classe e todos os seus descendentes.
2013-08-13 02:31:46 +00:00
# Classe base
class Humano
@@foo = 0
def self.foo
@@foo
end
def self.foo=(value)
@@foo = value
end
end
# classe filha
class Trabalhador < Humano
end
Humano.foo # 0
Trabalhador.foo # 0
Humano.foo = 2 # 2
Trabalhador.foo # 2
2016-06-26 13:05:04 +00:00
# Uma variável de instância não é compartilhada por suas classes descendentes.
2013-08-13 02:31:46 +00:00
class Humano
@bar = 0
def self.bar
@bar
end
def self.bar=(value)
@bar = value
end
end
class Doutor < Humano
end
Humano.bar # 0
Doutor.bar # nil
2016-10-27 08:13:37 +00:00
---
module ModuloDeExemplo
def foo
'foo'
end
end
# Incluir (include) módulos conecta seus métodos às instâncias da classe
# Herdar (extend) módulos conecta seus métodos à classe em si
class Pessoa
include ExemploDeModulo
end
class Livro
extend ExemploDeModulo
end
Pessoa.foo # => NoMethodError: undefined method `foo' for Pessoa:Class
Pessoa.new.foo # => 'foo'
Livro.foo # => 'foo'
Livro.new.foo # => NoMethodError: undefined method `foo'
# Callbacks são executados ao incluir e herdar um módulo
module ExemploDeConceito
def self.included(base)
base.extend(MetodosDeClasse)
base.send(:include, MetodosDeInstancia)
end
module MetodosDeClasse
def bar
'bar'
end
end
module MetodosDeInstancia
def qux
'qux'
end
end
end
class Algo
include ExemploDeConceito
end
Algo.bar # => 'bar'
Algo.qux # => NoMethodError: undefined method `qux'
Algo.new.bar # => NoMethodError: undefined method `bar'
Algo.new.qux # => 'qux'
2013-08-13 02:31:46 +00:00
```
2015-10-24 22:51:42 +00:00
2016-10-27 08:13:37 +00:00
## Recursos adicionais
2015-10-24 22:51:42 +00:00
2016-10-27 08:13:37 +00:00
- [Documentação oficial ](http://www.ruby-doc.org/core-2.1.1/ )
2015-10-24 22:51:42 +00:00
- [Ruby a partir de outras linguagens ](https://www.ruby-lang.org/en/documentation/ruby-from-other-languages/ )
- [Programming Ruby ](http://www.amazon.com/Programming-Ruby-1-9-2-0-Programmers/dp/1937785491/ )- Um mais antigo [free edition ](http://ruby-doc.com/docs/ProgrammingRuby/ ) e tambem uma versão online disponível.
- [Ruby Style Guide ](https://github.com/bbatsov/ruby-style-guide ) - Uma versão colaborativa de um *style-guide*