HarmonyOS鸿蒙Next中Napi执行上层回调时如何获取env
HarmonyOS鸿蒙Next中Napi执行上层回调时如何获取env Napi执行上层回调时,如何获取env,jni可通过jvm获取,ArkTS应该如何获得。执行回调时是否限制线程,是否需要限定在node的线程内
libuv处理方式是在注册JS回调时保存env。在callback中从env中获取对应的JS线程的loop,再调用libuv接口抛JS任务到loop中执行。
napi_create_thread_safe_function函数调用是会触发参数中的napi_threadsafe_function_call_js 函数,该函数可以获取env在js线程中执行,可参考如下方式:
// 指向napi_value js_cb
napi_ref cbObj = nullptr;
// 线程安全函数
napi_threadsafe_function tsfn;
// Native侧Value值
static int cValue;
// 子线程运行函数
static void CallJs(napi_env env, napi_value js_cb, void *context, void *data)
{
std::thread::id this_id = std::this_thread::get_id();
OH_LOG_INFO(LOG_APP, "threadId3 is +%{public}d", this_id);
// 获取引用值
napi_get_reference_value(env, cbObj, &js_cb);
// 创建一个ArkTS number作为ArkTS function的入参。
napi_value argv;
napi_create_int32(env, cValue, &argv);
napi_value result = nullptr;
napi_call_function(env, nullptr, js_cb, 1, &argv, &result);
napi_get_value_int32(env, result, &cValue);
napi_delete_reference(env, cbObj);
}
// Native 主线程
static napi_value ThreadsTest(napi_env env, napi_callback_info info)
{
// 从ArkTS侧获取的参数的数量
size_t argc = 1;
napi_value js_cb, work_name;
// 获取ArkTS参数
napi_get_cb_info(env, info, &argc, &js_cb, nullptr, nullptr);
// 指向napi_value js_cb 的 napi_ref cbObj
napi_create_reference(env, js_cb, 1, &cbObj);
// 通过UTF8编码的C字符串数据创建work_name
napi_create_string_utf8(env, "Work Item", NAPI_AUTO_LENGTH, &work_name);
// 创建线程安全函数
napi_create_threadsafe_function(env, js_cb, NULL, work_name, 0, 1, NULL, NULL, NULL, CallJs, &tsfn);
std::thread::id this_id = std::this_thread::get_id();
OH_LOG_INFO(LOG_APP, "threadId1 is +%{public}d", this_id);
// 其他线程中调用线程安全函数
std::thread t([]() {
// 可获取线程ID
std::thread::id this_id = std::this_thread::get_id();
OH_LOG_INFO(LOG_APP, "threadId2 is +%{public}d",this_id);
napi_acquire_threadsafe_function(tsfn);
napi_call_threadsafe_function(tsfn, NULL, napi_tsfn_blocking);
});
t.detach();
return NULL;
}
更多关于HarmonyOS鸿蒙Next中Napi执行上层回调时如何获取env的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
在HarmonyOS鸿蒙Next中,当使用Napi执行上层回调时,获取env的方式是通过回调函数的参数。Napi的回调函数通常会接收一个napi_env类型的参数,这个参数就是当前JavaScript运行环境的句柄。具体来说,当你在Native代码中定义一个回调函数并将其绑定到JavaScript时,回调函数的第一个参数就是napi_env。
例如,假设你在Native代码中定义了一个回调函数MyCallback,并且将其绑定到JavaScript的某个事件上,那么在回调函数内部,你可以直接通过第一个参数获取env:
void MyCallback(napi_env env, napi_callback_info info) {
// 在这里可以直接使用env
}
在这个回调函数中,env参数就是当前JavaScript运行环境的句柄,你可以使用它来执行各种Napi操作,比如创建JavaScript对象、调用JavaScript函数等。
需要注意的是,env的作用域仅限于当前回调函数内部,你不能在回调函数之外直接使用它。如果你需要在回调函数之外使用env,可以通过其他方式将其传递出去,比如通过全局变量或者函数参数。
总结来说,在HarmonyOS鸿蒙Next中,Napi执行上层回调时,env是通过回调函数的第一个参数直接获取的。
在HarmonyOS鸿蒙Next中,使用Napi执行上层回调时,可以通过napi_get_cb_info函数获取napi_env环境对象。具体步骤如下:
- 定义回调函数:在Native层定义回调函数,接收
napi_env和napi_callback_info参数。 - 获取环境对象:在回调函数中调用
napi_get_cb_info,传入napi_env和napi_callback_info,获取当前执行环境。
例如:
napi_value MyCallback(napi_env env, napi_callback_info info) {
napi_value thisArg;
size_t argc = 1;
napi_value args[1];
napi_get_cb_info(env, info, &argc, args, &thisArg, nullptr);
// 使用env进行后续操作
return nullptr;
}
通过这种方式,你可以在回调中获取并使用napi_env环境对象。

