嗨我想知道是否有人可以向我解释为什么写在下面的代码中的地图函数是写在它的书面方式。具体为什么我们需要做的在中间步骤的局部变量
results = letters.map do |letter| encrypted_letter = encrypt_letter(letter)
,而不是仅仅做
results = letters.map do |letter| encrypt_letter(letter)
class Encryptor
def cipher
{"a" => "n", "b" => "o", 'c' => 'p', 'd' => 'q',
'e' => 'r', 'f' => 's', 'g' => 't', 'h' => 'u',
'i' => 'v', 'j' => 'w', 'k' => 'x', 'l' => 'y',
'm' => 'z', 'n' => 'a', 'o' => 'b', 'p' => 'c',
'q' => 'd', 'r' => 'e', 's' => 'f', 't' => 'g',
'u' => 'h', 'v' => 'i', 'w' => 'j', 'x' => 'k',
'y' => 'l', 'z' => 'm'}
end
def encrypt_letter(letter)
lowercase_letter = letter.downcase
cipher[lowercase_letter]
end
def encrypt(string)
letters = string.split("")
results = letters.map do |letter|
encrypted_letter = encrypt_letter(letter)
end
results.join
end
def decrypt_letter(letter)
lowercase_letter = letter.downcase
cipher.key(lowercase_letter)
end
def decrypt(string)
letters = string.split("")
results = letters.map do |letter|
decrypted_letter = decrypt_letter(letter)
end
results.join
end
end
好,谢谢。我试图弄清楚它的相当一段时间 – JaTo
“有时程序员觉得他们的结果有一个明确的变量目的地,更舒服。”?我会更简单地说:写它的人不知道“地图”是如何工作的,而且写得过于冗长。中间变量有它们的位置,但不应该指定为只能使用一次。 @ Tinman ...... –
......我没有任何建议,这是很好的做法。我只是在做一个观察,并且有点舌尖。我不会完全假定程序员脑子里发生了什么。 – lurker