【发布时间】:2016-12-11 16:58:06
【问题描述】:
目标
找出我的代码出了什么问题,或者 underscore.js 节流阀是否正常工作。
背景
我在一个文件中有大量邮政编码,我正在阅读这些编码并将它们粘贴到控制台上。
我正在尝试使用Underscore.js throttle() function,但是我的代码在两次运行后停止(即使我有几十个),并且其余的值从未打印出来。
代码
我的代码在一个非常简单的 NodeJS 项目中。我创建了一个MCVE 我所面临的情况:
"use strict";
//requiremetns
let fs = require('fs');
let readLine = require('readline');
let _ = require('underscore');
//constants
const INPUT_FILE = 'dataset.txt';
const RADIX_CONVERSATION = 10;
const THROTTLE_DELAY = 500;
let init = function() {
let lineReader = readLine.createInterface({
input: fs.createReadStream(INPUT_FILE),
output: process.stdout,
terminal: false
});
let throttledRequestFn = _.throttle(requestFn, THROTTLE_DELAY);
lineReader.on('line', function(line) {
line = line.trim();
if (_.isNaN(parseInt(line, RADIX_CONVERSATION))) {
//Do some stuff
}
else {
throttledRequestFn('mahCountry', line);
}
});
};
let requestFn = function(country, postalCode){
console.log('request for ' + country + ' and postal ' + postalCode + ' done');
return false;
};
init();
在这里,我首先从读取文件开始,一次一行。然后如果我正在阅读的行是一个数字,我打印一些东西,否则什么都没有。
以下是测试文件:
Vietnam
000000
100000
160000
170000
180000
200000
220000
230000
240000
250000
260000
270000
280000
290000
300000
310000
320000
330000
350000
360000
380000
390000
400000
410000
420000
430000
440000
460000
480000
510000
520000
530000
550000
560000
570000
580000
590000
600000
620000
630000
640000
650000
660000
670000
700000
790000
800000
810000
820000
830000
840000
850000
860000
870000
880000
890000
900000
910000
920000
930000
940000
950000
960000
970000
问题
在我看来,我的代码应该每秒发出 2 个请求,每个请求之间有 500 毫秒的延迟。它应该打印测试文件中的所有代码。 但是,我从未见过任何超过第二个值的东西!为什么会这样?
【问题讨论】:
标签: javascript node.js underscore.js throttling