nodejs 异常捕获
(1)
function error() {
throw new Error(“catch me”);
}
error();
process.on(‘uncaughtException’, function (err) {
console.log(‘uncaughtException ->>>’,err);
});
(2)function sync_error() {
var r = Math.random() * 10;
console.log("random num is " + r);
if (r > 5) {
throw new Error("Error: random num" + r + " > 5");
}
}
setInterval(function () {
sync_error();
}, 1000);
process.on('uncaughtException', function (err) {
console.log('uncaughtException ->>>',err);
});
(3)
function async_error() {
setTimeout(function(){
var r = Math.random() * 10;
console.log("random num is " + r);
if (r > 5) {
throw new Error("Error: random num" + r + " > 5");
}
},10)
}
setInterval(function () {
try {
async_error();
} catch (err) {
console.log(err);
}
}, 1000)
process.on('uncaughtException', function (err) {
console.log(err);
});
第一种情况,捕获不到异常;第二种情况,捕获一次异常程序就退出;第三种情况,程序不会退出。为什么会出现这几种情况?
3 回复
1.你在抛出Error后才监听uncaughtException
当然捕获不到
process.on('uncaughtException', function (err) {
console.log('uncaughtException ->>>',err);
});
function error() {
throw new Errorjavascript:void(0);('catch me');
}
error();
// uncaughtException ->>> Error: catch me
// at ...
2.在interval内抛出Error,未被捕获,interval停止,Error继续抛出,未被捕获,触发uncaughtException,程序退出
3.interval内虽然发生了异常,但被捕获了所以不会使interval停止,程序可以继续运行
@dislido 但是第3中情况interval的try catch捕获不到settimout的异常,还是process.on捕获的啊
@chenqichenqi 看错了 3里的Error是timeout抛出去的,不会影响到interval,所以interval正常进行,程序不会退出