Domain(域)模块简化了异步代码的异常处理方式,可以捕捉处理try catch无法捕捉的异常。
引入
domain模块,把处理多个不同的IO的操作作为一个组。注册事件和回调到domain,当发生一个错误事件或抛出一个错误时,domain对象会被通知,不会丢失上下文环境,也不导致程序错误立即推出,与process.on('uncaughtException')不同。
Domain 模块可分为隐式绑定和显式绑定:
- 隐式绑定: 把在domain上下文中定义的变量,自动绑定到domain对象
- 显式绑定: 把不是在domain上下文中定义的变量,以代码的方式绑定到domain对
方法
domain.run(function)
在域的上下文运行提供的函数,隐式的绑定了所有的事件分发器,计时器和底层请求。
domain.add(emitter)
显式的增加事件
domain.remove(emitter)
删除事件。
domain.bind(callback)
返回的函数是一个对于所提供的回调函数的包装函数。当调用这个返回的函数被时,所有被抛出的错误都会被导向到这个域的 error 事件。
domain.intercept(callback)
和 domain.bind(callback) 类似。除了捕捉被抛出的错误外,它还会拦截 Error 对象作为参数传递到这个函数
domain.enter()
进入一个异步调用的上下文,绑定到domain。
domain.exit()
退出当前的domain,切换到不同的链的异步调用的上下文中。对应domain.enter()。
domain.dispose()
释放一个domain对象,让node进程回收这部分资源。
domain.create()
返回一个domain对象。
属性
domain.members
一个例子
创建domain.js,代码如下:
<span style="color: #008000;">//<span style="color: #008000;">创建域
<span style="color: #0000ff;">var domain1=<span style="color: #000000;">domain.create();
domain1.on("error",<span style="color: #0000ff;">function<span style="color: #000000;">(err){
console.log("domain1 处理错误"<span style="color: #000000;">,err.message);
});
<span style="color: #008000;">//<span style="color: #008000;">显示绑定
<span style="color: #000000;">domain1.add(emitter1);
emitter1.on("error",<span style="color: #0000ff;">function<span style="color: #000000;">(err){
console.log("监听器处理错误"<span style="color: #000000;">,err.message);
});
emitter1.emit("error",<span style="color: #0000ff;">new Error("通过监听器来处理"<span style="color: #000000;">));
emitter1.removeAllListeners("error"<span style="color: #000000;">);
emitter1.emit("error",<span style="color: #0000ff;">new Error("通过domain1 处理"<span style="color: #000000;">));
<span style="color: #0000ff;">var domain2=<span style="color: #000000;">domain.create();
domain2.on("error",<span style="color: #0000ff;">function<span style="color: #000000;">(err){
console.log("domain2 处理错误"<span style="color: #000000;">,err.message);
});
<span style="color: #008000;">//<span style="color: #008000;">隐式绑定
domain2.run(<span style="color: #0000ff;">function<span style="color: #000000;">(err){
<span style="color: #0000ff;">var emitter2 = <span style="color: #0000ff;">new<span style="color: #000000;"> EventEmitter();
emitter2.emit('error',<span style="color: #0000ff;">new Error('通过 domain2 处理'<span style="color: #000000;">));
});
domain1.remove(emitter1);
emitter1.emit('error',<span style="color: #0000ff;">new Error("转换为异常,系统将崩溃"));
运行
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。