Pergunta

Não estou claro sobre as diferenças entre a versão "atual" do Ruby (1.8) e a versão "nova" (1.9).Existe uma explicação “fácil” ou “simples” para as diferenças e por que são tão diferentes?

Foi útil?

Solução

Sam Ruby tem um apresentação de slides legal que descreve as diferenças.

No interesse de colocar essas informações em linha para facilitar a referência, e caso o link fique inoperante no futuro abstrato, aqui está uma visão geral dos slides de Sam.A apresentação de slides é menos complicada de revisar, mas ter tudo organizado em uma lista como esta também é útil.

Ruby 1.9 - Principais recursos

  • Desempenho
  • Fios/Fibras
  • Codificação/Unicode
  • gems está (principalmente) integrado agora
  • As instruções if não introduzem escopo em Ruby.

O que mudou?

Sequências de caracteres únicos.

Rubi 1.9

irb(main):001:0> ?c
=> "c"

Rubi 1.8.6

irb(main):001:0> ?c
=> 99

Índice de string.

Rubi 1.9

irb(main):001:0> "cat"[1]
=> "a"

Rubi 1.8.6

irb(main):001:0> "cat"[1]
=> 97

{"a","b"} não é mais compatível

Rubi 1.9

irb(main):002:0> {1,2}
SyntaxError: (irb):2: syntax error, unexpected ',', expecting tASSOC

Rubi 1.8.6

irb(main):001:0> {1,2}
=> {1=>2}

Ação: Converter para {1 => 2}


Array.to_s Agora contém pontuação

Rubi 1.9

irb(main):001:0> [1,2,3].to_s
=> "[1, 2, 3]"

Rubi 1.8.6

irb(main):001:0> [1,2,3].to_s
=> "123"

Ação: Use .join em vez disso


Dois pontos não são mais válidos em declarações When

Rubi 1.9

irb(main):001:0> case 'a'; when /\w/: puts 'word'; end
SyntaxError: (irb):1: syntax error, unexpected ':',
expecting keyword_then or ',' or ';' or '\n'

Rubi 1.8.6

irb(main):001:0> case 'a'; when /\w/: puts 'word'; end
word

Ação: Use ponto e vírgula, então, ou nova linha


Bloquear variáveis ​​agora sombreia variáveis ​​locais

Rubi 1.9

irb(main):001:0> i=0; [1,2,3].each {|i|}; i
=> 0
irb(main):002:0> i=0; for i in [1,2,3]; end; i
=> 3

Rubi 1.8.6

irb(main):001:0> i=0; [1,2,3].each {|i|}; i
=> 3

Hash.index Descontinuada

Rubi 1.9

irb(main):001:0> {1=>2}.index(2)
(irb):18: warning: Hash#index is deprecated; use Hash#key
=> 1
irb(main):002:0> {1=>2}.key(2)
=> 1

Rubi 1.8.6

irb(main):001:0> {1=>2}.index(2)
=> 1

Ação: Usar Hash.key


Fixnum.to_sym Agora se foi

Rubi 1.9

irb(main):001:0> 5.to_sym
NoMethodError: undefined method 'to_sym' for 5:Fixnum

Rubi 1.8.6

irb(main):001:0> 5.to_sym
=> nil

(Continuação) Ruby 1.9

# Find an argument value by name or index.
def [](index)
  lookup(index.to_sym)
end

svn.ruby-lang.org/repos/ruby/trunk/lib/rake.rb


Chaves hash agora não ordenadas

Rubi 1.9

irb(main):001:0> {:a=>"a", :c=>"c", :b=>"b"}
=> {:a=>"a", :c=>"c", :b=>"b"}

Rubi 1.8.6

irb(main):001:0> {:a=>"a", :c=>"c", :b=>"b"}
=> {:a=>"a", :b=>"b", :c=>"c"}

O pedido é um pedido de inserção


Expressões regulares Unicode mais rigorosas

Rubi 1.9

irb(main):001:0> /\x80/u
SyntaxError: (irb):2: invalid multibyte escape: /\x80/

Rubi 1.8.6

irb(main):001:0> /\x80/u
=> /\x80/u

tr e Regexp Agora entenda o Unicode

Rubi 1.9

unicode(string).tr(CP1252_DIFFERENCES, UNICODE_EQUIVALENT).
  gsub(INVALID_XML_CHAR, REPLACEMENT_CHAR).
  gsub(XML_PREDEFINED) {|c| PREDEFINED[c.ord]}

pack e unpack

Rubi 1.8.6

def xchr(escape=true)
  n = XChar::CP1252[self] || self
  case n when *XChar::VALID
    XChar::PREDEFINED[n] or 
      (n>128 ? n.chr : (escape ? "&##{n};" : [n].pack('U*')))
  else
    Builder::XChar::REPLACEMENT_CHAR
  end
end
unpack('U*').map {|n| n.xchr(escape)}.join

BasicObject Mais brutal do que BlankSlate

Rubi 1.9

irb(main):001:0> class C < BasicObject; def f; Math::PI; end; end; C.new.f
NameError: uninitialized constant C::Math

Rubi 1.8.6

irb(main):001:0> require 'blankslate'
=> true
irb(main):002:0> class C < BlankSlate; def f; Math::PI; end; end; C.new.f
=> 3.14159265358979

Ação: Usar ::Matemática::PI


Mudanças de delegação

Rubi 1.9

irb(main):002:0> class C < SimpleDelegator; end
=> nil
irb(main):003:0> C.new('').class
=> String

Rubi 1.8.6

irb(main):002:0> class C < SimpleDelegator; end
=> nil
irb(main):003:0> C.new('').class
=> C
irb(main):004:0>

Defeito 17700


O uso de $KCODE produz avisos

Rubi 1.9

irb(main):004:1> $KCODE = 'UTF8'
(irb):4: warning: variable $KCODE is no longer effective; ignored
=> "UTF8"

Rubi 1.8.6

irb(main):001:0> $KCODE = 'UTF8'
=> "UTF8"

instance_methods Agora uma matriz de símbolos

Rubi 1.9

irb(main):001:0> {}.methods.sort.last
=> :zip

Rubi 1.8.6

irb(main):001:0> {}.methods.sort.last
=> "zip"

Ação: Substitua instance_methods.include?com método_definido?


Codificação do arquivo de origem

Básico

# coding: utf-8

Emacs

# -*- encoding: utf-8 -*-

Shebang

#!/usr/local/rubybook/bin/ruby
# encoding: utf-8

Rosqueamento Real

  • Condições da corrida
  • Suposições de pedidos implícitas
  • Código de teste

O que há de novo?

Sintaxe alternativa para símbolo como chaves hash

Rubi 1.9

{a: b}

redirect_to action: show

Rubi 1.8.6

{:a => b}

redirect_to :action => show

Bloquear variáveis ​​locais

Rubi 1.9

[1,2].each {|value; t| t=value*value}

Métodos de injeção

Rubi 1.9

[1,2].inject(:+)

Rubi 1.8.6

[1,2].inject {|a,b| a+b}

to_enum

Rubi 1.9

short_enum = [1, 2, 3].to_enum
long_enum = ('a'..'z').to_enum
loop do
  puts "#{short_enum.next} #{long_enum.next}"
end

Nenhum bloqueio?Enum!

Rubi 1.9

e = [1,2,3].each

Abreviação Lambda

Rubi 1.9

p = -> a,b,c {a+b+c}
puts p.(1,2,3)
puts p[1,2,3]

Rubi 1.8.6

p = lambda {|a,b,c| a+b+c}
puts p.call(1,2,3)

Números complexos

Rubi 1.9

Complex(3,4) == 3 + 4.im

Decimal ainda não é o padrão

Rubi 1.9

irb(main):001:0> 1.2-1.1
=> 0.0999999999999999

“Propriedades” de Regex

Rubi 1.9

/\p{Space}/

Rubi 1.8.6

/[:space:]/

Splat no meio

Rubi 1.9

def foo(first, *middle, last)

(->a, *b, c {p a-c}).(*5.downto(1))

Fibras

Rubi 1.9

f = Fiber.new do
  a,b = 0,1
  Fiber.yield a
  Fiber.yield b
  loop do
    a,b = b,a+b
    Fiber.yield b
  end
end
10.times {puts f.resume}

Quebrar valores

Rubi 1.9

match =
   while line = gets
     next if line =~ /^#/
     break line if line.find('ruby')
   end

Métodos “aninhados”

Rubi 1.9

def toggle
  def toggle
    "subsequent times"
  end
  "first time"
end

AH!

Outras dicas

Uma grande diferença seria a mudança do intérprete de Matz para YARV, uma máquina virtual de bytecode que ajuda significativamente no desempenho.

Muitos agora recomendam A linguagem de programação Ruby sobre a Picareta - mais precisamente, ela tem todos os detalhes das diferenças 1.8/1.9.

Mais algumas mudanças:

Retornando um array singleton splat:

def function
  return *[1]
end

a=function
  • rubi 1.9:[1]
  • rubi 1.8:1

argumentos de matriz

def function(array)
  array.each { |v| p v }
end
function "1"
  • rubi 1.8:"1"
  • rubi 1.9:método indefinido `each' para "1":String
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top