无法理解 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();,但我认为这是一个坏习惯。