nodejs 异常捕获
发布于 7 年前 作者 chenqichenqi 4030 次浏览 来自 问答

(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正常进行,程序不会退出

回到顶部