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