Nazwane parametry w Ruby 2

Nie rozumiem całkowicie, jak nazwane parametry działają w Ruby 2.0.

def test(var1, var2, var3)
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) #wrong number of arguments (1 for 3) (ArgumentError)

to jest traktowane jak hash. I to jest bardzo zabawne, ponieważ używam nazwanych parametrów w Ruby 2.0 Imusi ustaw dla nich wartości domyślne:

def test(var1: "var1", var2: "var2", var3: "var3")
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) # ok => 1111 2222 var3-new

które bardzo przypominają zachowanie, które Ruby miał wcześniej przy domyślnych wartościach parametrów:

def test(var1="var1", var2="var2", var3="var3")
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) # ok but ... {:var3=>"var3-new", :var1=>1111, :var2=>2222} var2 var3

Wiem, dlaczego tak się dzieje i jak to działa.

Ale jestem po prostu ciekawy,musi Używam wartości domyślnych dla parametrów, jeśli używam nazwanych parametrów?

I czy ktoś może mi powiedzieć, jaka jest różnica między tymi dwoma?

def test1(var1="default value123")
  #.......
end

def test1(var1:"default value123")
  #.......
end

questionAnswers(8)

yourAnswerToTheQuestion