所以,我想模擬一些長時間的計算。爲此我計算斐波那契數。如果計算需要很長時間,我需要拒絕它。藍鳥承諾:爲什麼不超時?
問題:爲什麼TimeoutErrror
處理程序不起作用?如何修復代碼?
const expect = require('chai').expect
const Promise = require('bluebird')
function profib(n, prev = '0', cur = '1') {
return new Promise.resolve(n < 2)
.then(function(isTerm) {
if(isTerm) {
return cur
} else {
n = n - 2
return profib(n, cur, strAdd(cur, prev));
}
})
}
const TIMEOUT = 10000
const N = 20000
describe('recursion', function() {
it.only('cancelation', function() {
this.timeout(2 * TIMEOUT)
let prom = profib(N).timeout(1000)
.catch(Promise.TimeoutError, function(e) {
console.log('timeout', e)
return '-1'
})
return prom.then((num) => {
expect(num).equal('-1')
})
})
})
const strAdd = function(lnum, rnum) {
lnum = lnum.split('').reverse();
rnum = rnum.split('').reverse();
var len = Math.max(lnum.length, rnum.length),
acc = 0;
res = [];
for(var i = 0; i < len; i++) {
var subres = Number(lnum[i] || 0) + Number(rnum[i] || 0) + acc;
acc = ~~(subres/10); // integer division
res.push(subres % 10);
}
if (acc !== 0) {
res.push(acc);
}
return res.reverse().join('');
};
關於環境的一些信息:
➜ node -v
v6.3.1
➜ npm list --depth=0
├── [email protected]
├── [email protected]
└── [email protected]
您使用摩卡嗎?您使用的是什麼樣的跑步者? – Hosar
增加了關於環境的信息 – kharandziuk
你可以用JavaScript處理這種事情的唯一方法就是將你的處理切成小步驟,讓其他代碼比你的循環運行在這些步驟之間。一種有效的方法將涉及遞歸式的Promises。最好在WebWorker中,所以你不要拖慢UI過程。 – Touffy