AsyncContext

AsyncContext

Napi::AsyncWorker类可能并非适用于所有场景。当使用其他任何异步机制时,引入新的Napi::AsyncContext类是必要的,以确保运行时能正确跟踪异步操作。Napi::AsyncContext类可传递给Napi::Function::MakeCallback()方法,以正确恢复正确的异步执行上下文。

方法

构造函数

创建一个新的Napi::AsyncContext

cpp 复制代码
explicit Napi::AsyncContext::AsyncContext(napi_env env, const char* resource_name);
  • [in] env:用于创建Napi::AsyncContext的环境。
  • [in] resource_name:以空字符结尾的字符串,表示为async_hooks API 所暴露的诊断信息提供的资源类型标识符。

构造函数

创建一个新的Napi::AsyncContext

cpp 复制代码
explicit Napi::AsyncContext::AsyncContext(napi_env env, const char* resource_name, const Napi::Object& resource);
  • [in] env:用于创建Napi::AsyncContext的环境。
  • [in] resource_name:以空字符结尾的字符串,表示为async_hooks API 所暴露的诊断信息提供的资源类型标识符。
  • [in] resource:与异步操作相关联的对象,将传递给可能的async_hooks

析构函数

销毁Napi::AsyncContext实例。

cpp 复制代码
virtual Napi::AsyncContext::~AsyncContext();

Env

获取创建该异步上下文时的环境。

cpp 复制代码
Napi::Env Env() const;

返回创建该异步上下文的Napi::Env环境。

运算符

cpp 复制代码
Napi::AsyncContext::operator napi_async_context() const;

返回由Napi::AsyncContext对象包装的 Node-API 的napi_async_context。这可用于混合使用 C Node-API 和 node-addon-api。

示例

cpp 复制代码
#include "napi.h"

void MakeCallbackWithAsyncContext(const Napi::CallbackInfo& info) {
  Napi::Function callback = info[0].As<Napi::Function>();
  Napi::Object resource = info[1].As<Napi::Object>();

  // 创建一个新的异步上下文实例。
  Napi::AsyncContext context(info.Env(), "async_context_test", resource);

  // 使用异步上下文实例调用回调函数。
  callback.MakeCallback(Napi::Object::New(info.Env()),
      std::initializer_list<napi_value>{}, context);

  // 异步上下文实例在此处会自动销毁,因为它像`Napi::HandleScope`一样具有块作用域。
}
相关推荐
No0d1es14 分钟前
电子学会青少年软件编程(C语言)等级考试试卷(三级)2025年12月
c语言·c++·青少年编程·电子学会·三级
徐同保21 分钟前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
fanruitian22 分钟前
uniapp 创建项目
javascript·vue.js·uni-app
吕司24 分钟前
Qt的信号与槽
开发语言·qt
刘一说1 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
bjxiaxueliang1 小时前
一文掌握C/C++命名规范:风格、规则与实践详解
c语言·开发语言·c++
玄〤1 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法
一周七喜h1 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js
weixin_395448912 小时前
main.c_cursor_0202
前端·网络·算法
一起养小猫2 小时前
Flutter for OpenHarmony 实战:番茄钟应用完整开发指南
开发语言·jvm·数据库·flutter·信息可视化·harmonyos