无法理解 memoize 实现
Trouble understanding memoize implementation
answerKey[参数] 是如何工作的?如果 Array.prototype.slice.call(参数)
returns一个数组[157, 687],answerKey[parameters]是不是存储一个数组作为key?
function memoize(mathProblem) {
var answerKey = {};
return function(){
var parameters = Array.prototype.slice.call(arguments);
if (answerKey[parameters]) {
console.log('returning cached');
return answerKey[parameters];
} else {
answerKey[parameters] = mathProblem.apply(this, arguments);
return answerKey[parameters]
}
}
};
var multiply = function(a, b){
return a*b;
}
var memoMultiply = memoize(multiply);
console.log(memoMultiply(157, 687));
=>
107859
console.log(memoMultiply(157, 687))
=>
returning cached
107859
方括号表示法将数组转换为字符串
var answerKey = {};
var params = [157, 687];
answerKey[params] = 107859;
answerKey['157,687']; // 107859
所以是的,关键是作为字符串的数组内容。这不是很好的做法。
已请求编辑
一般来说,我尽量避免依赖于从 Array.prototype.toString()
创建的字符串,因为它有一些奇怪的行为
例如。嵌套数组被展平
[2, [3, 4], 5].toString(); // '2,3,4,5'
这正在丢失有关源数组的信息并且与
无法区分
[2, 3, 4, 5].toString();
为了解决这些问题,我建议通过 JSON.stringify();
传递数组
JSON.stringify([2, [3, 4], 5]); // '[2,[3,4],5]'
JSON.stringify([2, 3, 4, 5]); // '[2,3,4,5]'
此示例适用于 .toString();
,但我认为这是一个坏习惯。
answerKey[参数] 是如何工作的?如果 Array.prototype.slice.call(参数) returns一个数组[157, 687],answerKey[parameters]是不是存储一个数组作为key?
function memoize(mathProblem) {
var answerKey = {};
return function(){
var parameters = Array.prototype.slice.call(arguments);
if (answerKey[parameters]) {
console.log('returning cached');
return answerKey[parameters];
} else {
answerKey[parameters] = mathProblem.apply(this, arguments);
return answerKey[parameters]
}
}
};
var multiply = function(a, b){
return a*b;
}
var memoMultiply = memoize(multiply);
console.log(memoMultiply(157, 687));
=>
107859
console.log(memoMultiply(157, 687))
=>
returning cached
107859
方括号表示法将数组转换为字符串
var answerKey = {};
var params = [157, 687];
answerKey[params] = 107859;
answerKey['157,687']; // 107859
所以是的,关键是作为字符串的数组内容。这不是很好的做法。
已请求编辑
一般来说,我尽量避免依赖于从 Array.prototype.toString()
创建的字符串,因为它有一些奇怪的行为
例如。嵌套数组被展平
[2, [3, 4], 5].toString(); // '2,3,4,5'
这正在丢失有关源数组的信息并且与
无法区分[2, 3, 4, 5].toString();
为了解决这些问题,我建议通过 JSON.stringify();
JSON.stringify([2, [3, 4], 5]); // '[2,[3,4],5]'
JSON.stringify([2, 3, 4, 5]); // '[2,3,4,5]'
此示例适用于 .toString();
,但我认为这是一个坏习惯。