Node-API的数据类型

napi_status

是一个枚举数据类型,表示Node-API接口返回的状态信息。

每当调用一个Node-API函数,都会返回该值,表示操作成功与否的相关信息。

typedef enum {
    napi_ok,
    napi_invalid_arg,
    napi_object_expected,
    napi_string_expected,
    napi_name_expected,
    napi_function_expected,
    napi_number_expected,
    napi_boolean_expected,
    napi_array_expected,
    napi_generic_failure,
    napi_pending_exception,
    napi_cancelled,
    napi_escape_called_twice,
    napi_handle_scope_mismatch,
    napi_callback_scope_mismatch,
    napi_queue_full,
    napi_closing,
    napi_bigint_expected,
    napi_date_expected,
    napi_arraybuffer_expected,
    napi_detachable_arraybuffer_expected,
    napi_would_deadlock, /* unused */
    napi_no_external_buffers_allowed,
    napi_cannot_run_js
} napi_status;

napi_extended_error_info

一个结构体,在调用Node-API接口不成功时存储了较为详细的错误信息。

typedef struct {
    const char *error_message;
    void *engine_reserved;
    uint32_t engine_error_code;
    napi_status error_code;
} napi_extended_error_info;

napi_value

napi_value是一个C的结构体指针,表示一个ArkTS/JS对象的引用。napi_value持有了ArkTS/JS对象,同时,napi_value受napi_handle_scope管理,scope中napi_value持有的JS对象不会被释放;出scope后,napi_value将失效,不再持有对应的ArkTS/JS对象。

napi_env

  • 用于表示Node-API执行时的上下文,Native侧函数入参,并传递给函数中的Node-API接口。

  • napi_env与ArkTS/JS线程的上下文环境绑定,每一个napi_env都持有独立的运行时上下文环境,当ArkTS/JS线程退出之后,相应的napi_env将不再有效。

  • 禁止缓存napi_env,禁止在不同线程间传递napi_env。

napi_threadsafe_function

napi_threadsafe_function用来创建一个线程安全的ArkTS/JS函数,可以在不同的线程中调用。可以用于将异步操作的结果传递给ArkTS/JS环境,例如从另一个线程中读取数据或执行计算密集型操作。线程安全函数回调的执行仅在创建线程安全函数的ArkTS线程中执行。通过使用napi_threadsafe_function,可以实现ArkTS/JS和C++之间的高效通信,同时保持线程安全性。

napi_threadsafe_function_release_mode

该枚举类型定义了两个常量,用于指定以哪一种方式来释放线程安全函数。

typedef enum {
  napi_tsfn_release,
  napi_tsfn_abort
} napi_threadsafe_function_release_mode;

该值会传给napi_release_threadsafe_function。

napi_release_threadsafe_function(napi_threadsafe_function func,
                                 napi_threadsafe_function_release_mode mode);
  • mode值为napi_tsfn_release时:表示将tsfn中持有的线程数减一,当线程数减到0时,线程安全函数tsfn将被销毁。

  • mode值为napi_tsfn_abort时:该tsfn关闭,不能再调用此tsfn。

    如果设置为napi_tsfn_abort,利用napi_call_threadsafe_function接口调用此tsfn时,该行为可能导致UAF问题————当napi_tsfn_abort被设置时,tsfn立刻关闭,不能再被调用。如果此时调用napi_call_threadsafe_function,系统可能会返回napi_closing状态,表示tsfn正在关闭,但是传递给tsfn的data并未被放入队列中,这意味着data可能未被正确处理。如果data指向的内存已经被释放(例如,tsfn的资源被释放),但调用者仍然尝试访问或使用data,就会出现UAF(Use-After-Free)问题。

napi_threadsafe_function_call_mode

该枚举类型定义了两个常量,用于指定线程安全函数的调用模式。

数据结构如下所示:

  1. typedef enum {
  2. napi_tsfn_nonblocking,
  3. napi_tsfn_blocking
  4. } napi_threadsafe_function_call_mode;
  • napi_tsfn_nonblocking:napi_call_threadsafe_function是非阻塞的,如果队列已满,则返回napi_queue_full,从而阻止数据添加到队列中。

  • napi_tsfn_blocking:napi_call_threadsafe_function是阻塞的,直至队列中有空间可用。

内存管理类型

Node-API包含以下内存管理类型:

napi_handle_scope

napi_handle_scope数据类型是用来管理ArkTS/JS对象的生命周期的。它允许ArkTS/JS对象在一定范围内保持活动状态,以便在ArkTS/JS代码中使用。在创建napi_handle_scope时,所有在该范围内创建的ArkTS/JS对象都会保持活动状态,直到scope被关闭。这样可以做到ArkTS/JS对象生命周期最小化,避免发生内存泄漏问题。同时,napi_handle_scope也可参考生命周期类问题注意事项

napi_escapable_handle_scope

  • 由napi_open_escapable_handle_scope接口创建,由napi_close_escapable_handle_scope接口关闭。

  • 表示一种特殊类型的句柄范围,用于将在escapable_handle_scope范围内创建的值返回给父scope。

  • 用于napi_escape_handle接口,将ArkTS/JS对象逃逸到父scope,以便在外部作用域使用。

napi_ref

指向napi_value,允许用户管理ArkTS/JS值的生命周期。

napi_type_tag

该结构体定义了一个包含两个无符号64位整数的类型标签,用于标识一个Node-API值的类型信息。

  1. typedef struct {
  2. uint64_t lower;
  3. uint64_t upper;
  4. } napi_type_tag;
  • 存储了两个无符号64位整数的128位值,用它来标记ArkTS/JS对象,确保它们属于某种类型。

  • 比napi_instanceof更强的类型检查,如果对象的原型被操纵,napi_instanceof可能会存在误报。

  • type_tag与napi_wrap结合非常有用,因为它确保从包装对象检索的指针可以安全地转换为与先前应用于JavaScript对象的类型标记相对应的Native类型。

napi_async_cleanup_hook_handle

napi_async_cleanup_hook_handle是Node-API中用于管理异步资源生命周期的一种机制。它允许注册一个清理钩子(cleanup hook),该钩子仅在当前napi_env环境生命周期结束时被调用。通过使用 napi_async_cleanup_hook_handle,可以确保某些异步资源在环境销毁前得到妥善释放,从而避免资源泄漏。此外,在Node-API实现中,只要该结构未被释放,会延迟整个 napi_env 环境的销毁。在HarmonyOS中,该接口的行为基本等同于env生命周期相关的清理钩子,除了支持重复注册相同的上下文数据(data)外,其余行为与标准的env清理钩子一致。

napi_critical_scope(扩展能力)

napi_critical_scope是Node-API中,用于创建临界接口执行环境的机制。它由napi_open_critical_scope接口创建,由napi_close_critical_scope接口关闭。

临界接口:需要在临界区作用域内执行的接口,通常接口名中含有critical关键字。

napi_strong_ref(扩展能力)

指向napi_value,允许用户管理ArkTS对象的生命周期。

提示: napi_strong_ref与napi_ref相比,具有更高的创建效率,但支持的功能受限(如:不支持强弱引用转换等)。

napi_sendable_ref(扩展能力)

指向napi_value,允许调用者管理Sendable ArkTS对象的生命周期,并支持跨ArkTS线程操作napi_sendable_ref。

提示: 与napi_ref相比,napi_sendable_ref支持跨ArkTS线程操作(例如,在A线程创建napi_sendable_ref,B线程通过napi_sendable_ref获取napi_value,C线程删除napi_sendable_ref。调用者需保证调用时序。),但功能上有以下限制:被引用napi_value必须是Sendable的,不支持强弱引用转换。

回调类型

Node-API包含以下回调类型:

napi_callback_info

Native侧获取JS侧参数信息,传递给napi_get_cb_info,用于获取JS侧入参信息。

napi_callback

表示用户定义的Native函数,暴露给ArkTS/JS,即ArkTS/JS侧调用的接口;一般不需要在callback中创建handle或者callback scope。

基本用法如下:

  1. typedef napi_value (*napi_callback)(napi_env, napi_callback_info);

napi_finalize

函数指针,用于传入napi_create_threadsafe_function、napi_set_instance_data、napi_wrap、napi_add_finalizer等接口。napi_finalize在对象被回收时会被调用。

napi_async_execute_callback

函数指针,用于napi_create_async_work接口。

  • 异步执行的Native函数,从工作池线程调用,可与事件循环线程并行执行。

  • 函数实现中必须避免调用非线程安全的Node-API。

  • Node-API调用可以在napi_async_complete_callback中执行。

napi_async_complete_callback

napi_async_complete_callback用于异步操作完成后的回调。当需要进行异步操作时,可以使用napi_create_async_work函数创建一个异步操作任务,并指定一个napi_async_complete_callback回调函数,在异步操作完成后会自动调用该回调函数,以便进行后续的处理。该回调函数的参数包括当前异步操作任务的状态和返回值等信息,可以根据这些信息进行相应的处理。

napi_threadsafe_function_call_js

函数指针,在事件循环线程中执行,可与ArkTS/JS交互,从而实现更加复杂的功能,用于napi_create_threadsafe_function(napi_env env,…,napi_threadsafe_function_call_js call_js_cb,...)接口。

napi_cleanup_hook

函数指针,用于napi_add_env_cleanup_hook接口,当环境销毁时会被执行。

napi_async_cleanup_hook

函数指针,用于napi_add_async_cleanup_hook接口,当环境销毁时会被执行。

调度优先级

QoS决定了线程调度的优先级,等级定义如下:

  1. typedef enum {
  2. napi_qos_background = 0,
  3. napi_qos_utility = 1,
  4. napi_qos_default = 2,
  5. napi_qos_user_initiated = 3,
  6. } napi_qos_t;
QoS等级 适用场景
napi_qos_background 低等级,用户不可见任务,例如数据同步、备份。
napi_qos_utility 中低等级,不需要立即看到响应效果的任务,例如下载或导入数据。
napi_qos_default 默认。
napi_qos_user_initiated 高等级,用户触发并且可见进展,例如打开文档。

事件循环模式

napi提供了运行底层事件循环的两种模式, 其定义如下:

  1. typedef enum {
  2. napi_event_mode_default = 0,
  3. napi_event_mode_nowait = 1,
  4. } napi_event_mode;
事件循环运行模式 解释说明
napi_event_mode_default 阻塞式的运行底层事件循环,直到循环中没有或活跃的uv_handle句柄时退出事件循环。
napi_event_mode_nowait 非阻塞式的运行底层事件循环,尝试去处理一个任务,处理完之后退出事件循环;如果事件循环中没有任务,立刻退出事件循环。

线程安全任务优先级

napi提供了线程安全任务的优先级, 底层任务队列中的任务会根据其优先级被依次执行, 优先级的定义如下:

  1. typedef enum {
  2. napi_priority_immediate = 0,
  3. napi_priority_high = 1,
  4. napi_priority_low = 2,
  5. napi_priority_idle = 3,
  6. } napi_task_priority;
任务优先级 解释说明
napi_priority_immediate 该优先级的级别最高。
napi_priority_high 该优先级的级别低于napi_priority_immediate。
napi_priority_low 该优先级的级别低于napi_priority_immediate和napi_priority_high。
napi_priority_idle 该优先级的级别最低。

支持的Node-API接口

Node-API接口在Node.js提供的原生模块基础上扩展,目前支持部分接口,具体可见下文。

异步安全线程相关

接口 功能说明
napi_create_threadsafe_function 创建线程安全函数。
napi_get_threadsafe_function_context 获取线程安全函数中的context。
napi_call_threadsafe_function 调用线程安全函数。
napi_acquire_threadsafe_function 指示线程安全函数可以开始使用。
napi_release_threadsafe_function 指示线程安全函数将停止使用。
napi_ref_threadsafe_function 指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。
napi_unref_threadsafe_function 指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。

buffer相关

接口 功能说明
napi_create_buffer 创建并获取一个指定大小的ArkTS Buffer。
napi_create_buffer_copy 创建并获取一个指定大小的ArkTS Buffer,并以给定数据进行初始化。
napi_create_external_buffer 创建并获取一个指定大小的ArkTS Buffer,使用给定的数据作为buffer对象的底层缓冲区,该接口可为Buffer附带额外数据。
napi_get_buffer_info 获取JS Buffer底层data及其长度。
napi_is_buffer 判断给定JS value是否为Buffer对象。
napi_create_external_arraybuffer 分配一个附加有外部数据的JS ArrayBuffer。

string相关

接口 功能说明
napi_create_string_utf16 通过UTF16编码的C字符串数据创建ArkTS String。
napi_get_value_string_utf16 获取给定ArkTS value对应的UTF16编码的字符串。
napi_create_string_latin1 通过ISO-8859-1编码的C字符串数据创建ArkTS String。
napi_create_string_utf8 通过UTF8编码的C字符串数据创建ArkTS String。
napi_get_value_string_latin1 获取给定ArkTS value对应的ISO-8859-1编码的字符串。
napi_get_value_string_utf8 获取给定ArkTS value对应的UTF8编码的字符串。
napi_create_external_string_utf16 通过给定的UTF-16编码的字符串缓冲区来创建ArkTS字符串,该方法能避免字符串的内存拷贝。
napi_create_external_string_ascii 通过给定的ASCII编码的字符串缓冲区来创建ArkTS字符串,该方法能避免字符串的内存拷贝。

date相关

接口 功能说明
napi_create_date 通过一个C的double数据创建ArkTS Date。
napi_get_date_value 获取给定ArkTS Date对应的C double值。
napi_is_date 判断给定ArkTS value是否为ArkTS Date对象。

arraybuffer相关

接口 功能说明
napi_get_arraybuffer_info 获取ArrayBuffer的底层缓冲区及其长度。
napi_is_arraybuffer 判断给定ArkTS value是否为ArrayBuffer。
napi_detach_arraybuffer 分离给定ArrayBuffer的底层数据。
napi_is_detached_arraybuffer 判断给定的ArrayBuffer是否已被分离。
napi_create_arraybuffer 创建并获取一个指定大小的JS ArrayBuffer。

module相关

接口 功能说明
napi_module_register native模块注册接口。

生命周期相关

接口 功能说明
napi_open_handle_scope 创建一个napi_handle_scope。需要使用napi_close_handle_scope进行关闭。
napi_close_handle_scope 关闭传入的napi_handle_scope,关闭后,全部在其中产生的napi_value都将被关闭。
napi_open_escapable_handle_scope 创建出一个可逃逸的handle scope,可将范围内声明的值返回到父作用域。需要使用napi_close_escapable_handle_scope进行关闭。
napi_close_escapable_handle_scope 关闭传入的可逃逸的handle scope。
napi_escape_handle 提升传入的JS Object的生命周期到其父作用域。
napi_create_reference 为Object创建一个napi_ref。调用者需要自己管理napi_ref生命周期。
napi_delete_reference 删除传入的napi_ref。
napi_reference_ref 增加传入的napi_ref的引用计数,并获取新的计数。
napi_reference_unref 减少传入的napi_ref的引用计数,并获取新的计数。
napi_get_reference_value 获取与napi_ref相关联的JS Object。
napi_add_finalizer 当ArkTS Object中的对象被垃圾回收时调用注册的napi_finalize回调。

promise相关

接口 功能说明
napi_create_promise 创建一个Promise对象。
napi_resolve_deferred 对Promise关联的deferred对象进行兑现。
napi_reject_deferred 对Promise关联的deferred对象进行拒绝。
napi_is_promise 判断给定napi_value是否为Promise对象。

array相关

接口 功能说明
napi_create_array 创建一个ArkTS Array。
napi_create_array_with_length 创建并获取一个指定长度的ArkTS Array。
napi_get_array_length 获取array的length。
napi_is_array 判断给定ArkTS value是否为array。
napi_set_element 在给定Object的指定索引处,设置属性值。
napi_get_element 获取给定Object指定索引处的元素。
napi_has_element 若给定Object的指定索引处拥有属性。
napi_delete_element 尝试删除给定Object的指定索引处的元素。
napi_create_typedarray 通过现有的ArrayBuffer创建一个ArkTS TypeArray。
napi_is_typedarray 判断给定ArkTS value是否为TypeArray。
napi_get_typedarray_info 获取给定TypedArray的各种属性(例如:类型,长度,字节偏移量,ArrayBuffer等)。
napi_create_dataview 通过现有的ArrayBuffer创建一个ArkTS DataView。
napi_is_dataview 判断给定ArkTS value是否为DataView。
napi_get_dataview_info 获取给定DataView的各种属性。

primitive相关

接口 功能说明
napi_get_boolean 根据给定的C boolean值,获取JS Boolean对象。
napi_get_global 获取global对象。
napi_get_null 获取null对象。
napi_get_undefined 获取undefined对象。
napi_coerce_to_bool 将给定的JS value强转成JS Boolean。
napi_coerce_to_number 将给定的JS value强转成JS Number。
napi_coerce_to_object 将给定的JS value强转成JS Object。
napi_coerce_to_string 将给定的JS value强转成JS String。

class相关

接口 功能说明
napi_new_instance 通过给定的构造函数,构建一个实例。
napi_get_new_target 获取构造函数调用的new.target。
napi_define_class 定义与C++类相对应的JavaScript类。
napi_wrap 在ArkTS对象上绑定一个Node-API模块对象实例。这个函数通常在将Node-API模块对象与ArkTS对象进行绑定时使用,以便在ArkTS中使用Native方法和属性。
napi_unwrap 从ArkTS对象上获取之前绑定的Node-API模块对象实例。
napi_remove_wrap 从ArkTS对象上获取之前绑定的Node-API模块对象实例,并解除绑定。

object相关

接口 功能说明
napi_get_prototype 获取给定ArkTS Object的prototype。
napi_create_object 创建一个默认的ArkTS Object。
napi_object_freeze 冻结给定的对象。
napi_object_seal 密封给定的对象。
napi_typeof 获取给定ArkTS value的ArkTS Type。
napi_instanceof 判断给定object是否为给定constructor的实例。
napi_type_tag_object 将tag指针的值与Object关联。
napi_check_object_type_tag 判断给定的tag指针是否被关联到了ArkTS Object上。
napi_create_symbol 创建一个ArkTS Symbol对象。
napi_create_external 用于创建一个ArkTS外部对象,该对象可以用于将C/C++中的自定义数据结构或对象传递到JS中,并且可以在ArkTS中访问其属性和方法。
napi_get_value_external 用于获得napi_create_external创建的绑定了外部数据的ArkTS值,此函数可以在ArkTS和C/C++之间传递数据。

基本数据类型相关

接口 功能说明
napi_create_int32 通过一个C的int32数据创建JS number。
napi_create_uint32 通过一个C的uint32数据创建JS number。
napi_create_int64 通过一个C的int64数据创建JS number。
napi_create_double 通过一个C的double数据创建JS number。
napi_get_value_int32 获取给定JS number对应的C int32值。
napi_get_value_uint32 获取给定JS number对应的C uint32值。
napi_get_value_int64 获取给定JS number对应的C int64值。
napi_get_value_double 获取给定JS number对应的C double值。
napi_get_value_bool 获取给定js Boolean对应的C bool值。

bigint相关

接口 功能说明
napi_create_bigint_int64 通过一个C的int64数据创建JS BigInt。
napi_create_bigint_uint64 通过一个C的uint64数据创建JS BigInt。
napi_create_bigint_words 通过一个C的uint64数组创建单个JS BigInt。
napi_get_value_bigint_int64 获取给定JS BigInt对应的C int64值。
napi_get_value_bigint_uint64 获取给定JS BigInt对应的C uint64值。
napi_get_value_bigint_words 获取给定JS BigInt对应的信息,包括符号位、64位小端序数组和数组中的元素个数。

异常和错误相关

接口 功能说明
napi_throw 抛出一个JS value。
napi_throw_error 用于抛出一个带文本信息的ArkTS Error。
napi_throw_type_error 抛出一个带文本信息的ArkTS TypeError。
napi_throw_range_error 抛出一个带文本信息的ArkTS RangeError。
napi_is_error 判断napi_value是否表示为一个error对象。
napi_create_error 创建并获取一个带文本信息的ArkTS Error。
napi_create_type_error 创建并获取一个带文本信息的ArkTS Error对象
napi_create_range_error 创建并获取一个带文本信息的ArkTS Error对象。
napi_get_and_clear_last_exception 获取并清除最近一次出现的异常。
napi_is_exception_pending 判断是否出现了异常。
napi_fatal_error 引发致命错误以立即终止进程。
napi_get_last_error_info 获取napi_extended_error_info结构体,其中包含最近一次出现的error信息。
napi_fatal_exception 抛出一个致命异常并终止进程, 同时产生相应的crash日志。

属性相关

接口 功能说明
napi_get_property_names 以字符串数组的形式获取对象的可枚举属性的名称。
napi_set_property 对给定Object设置属性。
napi_get_property 获取给定Object的给定属性。
napi_has_property 判断给定对象中是否存在给定属性。
napi_delete_property 尝试从给定Object中删除给定key属性。
napi_has_own_property 判断给定Object中是否有名为key的own property。
napi_set_named_property 对给定Object设置一个给定名称的属性。
napi_get_named_property 获取给定Object中指定名称的属性。
napi_has_named_property 判断给定Object中是否有给定名称的属性。
napi_define_properties 批量的向给定Object中定义属性。
napi_get_all_property_names 获取一个数组,其中包含此对象过滤后的属性名称。

异步任务相关

接口 功能说明
napi_create_async_work 创建一个异步工作对象。
napi_delete_async_work 释放先前创建的异步工作对象。
napi_queue_async_work 将异步工作对象加到队列,由底层去调度执行。
napi_cancel_async_work 取消入队的异步任务。

自定义异步操作

接口 功能说明
napi_async_init 创建一个异步资源上下文环境(不支持与async_hook相关能力)。
napi_make_callback 在异步资源上下文环境中回调JS函数(不支持与async_hook相关能力)。
napi_async_destroy 销毁先前创建的异步资源上下文环境(不支持与async_hook相关能力)。
napi_open_callback_scope 创建一个回调作用域(不支持与async_hook相关能力)。
napi_close_callback_scope 关闭先前创建的回调作用域(不支持与async_hook相关能力)。

uv相关

接口 功能说明
napi_get_uv_event_loop 获取当前libuv loop实例。

函数调用

接口 功能说明
napi_call_function 在C/C++侧调用JS方法。
napi_get_cb_info 从给定的callback info中获取有关调用的详细信息,如参数和this指针。

环境生命周期

接口 功能说明
napi_set_instance_data 绑定与当前运行的环境相关联的数据项。
napi_get_instance_data 检索与当前运行的环境相关联的数据项。

对象生命周期管理

接口 功能说明
napi_add_env_cleanup_hook 注册环境清理钩子函数。
napi_remove_env_cleanup_hook 取消环境清理钩子函数。
napi_add_async_cleanup_hook 注册清理异步钩子函数。
napi_remove_async_cleanup_hook 取消清理异步钩子函数。

扩展能力

Node-API组件扩展的符号列表

接口 功能说明
napi_queue_async_work_with_qos 将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。
napi_run_script_path 运行指定的abc文件。
napi_load_module 将abc文件作为模块加载,返回模块的命名空间。
napi_load_module_with_info 将abc文件作为模块加载,返回模块的命名空间,可在ArkTS基础运行时环境中使用。
napi_create_object_with_properties 使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为string,且不可转为number。
napi_create_object_with_named_properties 使用给定的napi_value和键名创建js Object。键名必须为string,且不可转为number。
napi_coerce_to_native_binding_object 强制将js Object和Native对象绑定。
napi_create_ark_runtime 创建基础运行时环境。
napi_destroy_ark_runtime 销毁基础运行时环境。
napi_run_event_loop 启动底层的事件循环。
napi_stop_event_loop 停止底层的事件循环。
napi_serialize 将ArkTS对象序列化为native数据。
napi_deserialize 将native数据反序列化为ArkTS对象。
napi_delete_serialization_data 删除序列化数据。
napi_call_threadsafe_function_with_priority 按照指定的优先级和入队策略,将任务投递到ArkTS主线程中。
napi_is_sendable 判断给定的JS value是否是Sendable的。
napi_define_sendable_class 创建一个Sendable类。
napi_create_sendable_object_with_properties 使用给定的napi_property_descriptor创建一个Sendable对象。
napi_create_sendable_array 创建一个Sendable数组。
napi_create_sendable_array_with_length 创建一个指定长度的Sendable数组。
napi_create_sendable_arraybuffer 创建一个Sendable ArrayBuffer。
napi_create_sendable_typedarray 创建一个Sendable TypedArray。
napi_wrap_sendable 包裹一个native实例到ArkTS对象中。
napi_wrap_sendable_with_size 包裹一个native实例到ArkTS对象中并指定大小。
napi_unwrap_sendable 获取ArkTS对象包裹的native实例。
napi_remove_wrap_sendable 移除并获取ArkTS对象包裹的native实例,移除后回调将不再触发,需手动delete释放内存。
napi_wrap_enhance 在ArkTS对象上绑定一个native对象实例并指定实例大小,运行时会统计传入的实例大小并将其累加,当累计大小达到GC触发阈值时,运行时会启动垃圾回收流程。开发者可以指定绑定的回调函数是否异步执行,如果是异步执行,回调函数必须保证是线程安全的。
napi_create_ark_context 创建一个新的上下文环境。
napi_switch_ark_context 切换到指定的运行时上下文环境。
napi_destroy_ark_context 销毁通过napi_create_ark_context创建的上下文环境。
napi_open_critical_scope 打开临界区作用域。
napi_close_critical_scope 关闭临界区作用域。
napi_get_buffer_string_utf16_in_critical_scope 获取ArkTS String的UTF-16编码内存缓冲区数据。
napi_create_strong_reference 创建指向ArkTS对象的强引用。
napi_delete_strong_reference 删除强引用。
napi_get_strong_reference_value 根据强引用对象获取其关联的ArkTS对象值。
napi_create_strong_sendable_reference 创建指向Sendable ArkTS对象的Sendable强引用。
napi_delete_strong_sendable_reference 删除Sendable强引用。
napi_get_strong_sendable_reference_value 根据Sendable强引用获取其关联的ArkTS对象值。

napi_queue_async_work_with_qos

  1. napi_status napi_queue_async_work_with_qos(napi_env env,
  2. napi_async_work work,
  3. napi_qos_t qos);

用法同napi_queue_async_work,但可以指定QoS等级。napi_queue_async_work_with_qos使用方法可参考指定异步任务调度优先级。QoS详细介绍可参考QoS 开发指导

napi_run_script_path

  1. napi_status napi_run_script_path(napi_env env,
  2. const char* abcPath,
  3. napi_value* result);

**注:**使用限制说明文档:使用napi_run_script_path接口执行包内abc文件的使用限制

napi_load_module

  1. napi_status napi_load_module(napi_env env,
  2. const char* path,
  3. napi_value* result);

napi_create_object_with_properties

  1. napi_status napi_create_object_with_properties(napi_env env,
  2. napi_value* result,
  3. size_t property_count,
  4. const napi_property_descriptor* properties);

napi_create_object_with_named_properties

  1. napi_status napi_create_object_with_named_properties(napi_env env,
  2. napi_value* result,
  3. size_t property_count,
  4. const char** keys,
  5. const napi_value* values);

napi_coerce_to_native_binding_object

  1. napi_status napi_coerce_to_native_binding_object(napi_env env,
  2. napi_value js_object,
  3. napi_native_binding_detach_callback detach_cb,
  4. napi_native_binding_attach_callback attach_cb,
  5. void* native_object,
  6. void* hint);

napi_create_ark_runtime

  1. napi_status napi_create_ark_runtime(napi_env *env);

使用napi_create_ark_runtime、napi_destroy_ark_runtime接口创建ArkTS运行时环境

napi_destroy_ark_runtime

  1. napi_status napi_destroy_ark_runtime(napi_env *env);

napi_run_event_loop

  1. napi_status napi_run_event_loop(napi_env env, napi_event_mode mode);

开发者只能在自己通过napi_create_ark_runtime创建的ArkTS运行环境中调用napi_run_event_loop与napi_stop_event_loop接口,使用方法可参考使用扩展的Node-API接口在异步线程中运行和停止事件循环

napi_stop_event_loop

  1. napi_status napi_stop_event_loop(napi_env env);

napi_serialize

  1. napi_status napi_serialize(napi_env env,
  2. napi_value object,
  3. napi_value transfer_list,
  4. napi_value clone_list,
  5. void** result);

napi_deserialize

  1. napi_status napi_deserialize(napi_env env, void* buffer, napi_value* object);

napi_delete_serialization_data

  1. napi_status napi_delete_serialization_data(napi_env env, void* buffer);

napi_call_threadsafe_function_with_priority

  1. napi_status napi_call_threadsafe_function_with_priority(napi_threadsafe_function func,
  2. void *data,
  3. napi_task_priority priority,
  4. bool isTail);

napi_is_sendable

  1. napi_status napi_is_sendable(napi_env env, napi_value value, bool* result);

napi_define_sendable_class

  1. napi_status napi_define_sendable_class(napi_env env,
  2. const char* utf8name,
  3. size_t length,
  4. napi_callback constructor,
  5. void* data,
  6. size_t property_count,
  7. const napi_property_descriptor* properties,
  8. napi_value parent,
  9. napi_value* result);

napi_create_sendable_object_with_properties

  1. napi_status napi_create_sendable_object_with_properties(napi_env env,
  2. size_t property_count,
  3. const napi_property_descriptor* properties,
  4. napi_value* result);

napi_create_sendable_array

  1. napi_status napi_create_sendable_array(napi_env env, napi_value* result);

napi_create_sendable_array_with_length

  1. napi_status napi_create_sendable_array_with_length(napi_env env, size_t length, napi_value* result);

napi_create_sendable_arraybuffer

  1. napi_status napi_create_sendable_arraybuffer(napi_env env, size_t byte_length, void** data, napi_value* result);

napi_create_sendable_typedarray

  1. napi_status napi_create_sendable_typedarray(napi_env env,
  2. napi_typedarray_type type,
  3. size_t length,
  4. napi_value arraybuffer,
  5. size_t byte_offset,
  6. napi_value* result);

napi_wrap_sendable

  1. napi_status napi_wrap_sendable(napi_env env,
  2. napi_value js_object,
  3. void* native_object,
  4. napi_finalize finalize_cb,
  5. void* finalize_hint);

napi_wrap_sendable_with_size

  1. napi_status napi_wrap_sendable_with_size(napi_env env,
  2. napi_value js_object,
  3. void* native_object,
  4. napi_finalize finalize_cb,
  5. void* finalize_hint,
  6. size_t native_binding_size);

napi_unwrap_sendable

  1. napi_status napi_unwrap_sendable(napi_env env, napi_value js_object, void** result);

napi_remove_wrap_sendable

  1. napi_status napi_remove_wrap_sendable(napi_env env, napi_value js_object, void** result);

napi_wrap_enhance

  1. napi_status napi_wrap_enhance(napi_env env,
  2. napi_value js_object,
  3. void* native_object,
  4. napi_finalize finalize_cb,
  5. bool async_finalizer,
  6. void* finalize_hint,
  7. size_t native_binding_size,
  8. napi_ref* result);

napi_create_ark_context

  1. napi_status napi_create_ark_context(napi_env env,
  2. napi_env* newEnv);

napi_switch_ark_context

  1. napi_status napi_switch_ark_context(napi_env env);

napi_destroy_ark_context

  1. napi_status napi_destroy_ark_context(napi_env env);

napi_open_critical_scope

  1. napi_status napi_open_critical_scope(napi_env env, napi_critical_scope* scope);

napi_close_critical_scope

  1. napi_status napi_close_critical_scope(napi_env env, napi_critical_scope scope);

napi_get_buffer_string_utf16_in_critical_scope

  1. napi_status napi_get_buffer_string_utf16_in_critical_scope(napi_env env,
  2. napi_value value,
  3. const char16_t** buffer,
  4. size_t* length);

napi_create_strong_reference

  1. napi_status napi_create_strong_reference(napi_env env, napi_value value, napi_strong_ref* result);

napi_delete_strong_reference

  1. napi_status napi_delete_strong_reference(napi_env env, napi_strong_ref ref)

napi_get_strong_reference_value

  1. napi_status napi_get_strong_reference_value(napi_env env, napi_strong_ref ref, napi_value* result)

napi_create_external_string_utf16

  1. napi_status napi_create_external_string_utf16(napi_env env,
  2. const char16_t* str,
  3. size_t length,
  4. napi_finalize_callback finalize_callback,
  5. void* finalize_hint,
  6. napi_value* result);

napi_create_external_string_ascii

  1. napi_status napi_create_external_string_ascii(napi_env env,
  2. const char* str,
  3. size_t length,
  4. napi_finalize_callback finalize_callback,
  5. void* finalize_hint,
  6. napi_value* result);

napi_create_strong_sendable_reference

  1. napi_status napi_create_strong_sendable_reference(napi_env env,
  2. napi_value value,
  3. napi_sendable_ref* result);

napi_delete_strong_sendable_reference

  1. napi_status napi_delete_strong_sendable_reference(napi_env env, napi_sendable_ref ref);

napi_get_strong_sendable_reference_value

  1. napi_status napi_get_strong_sendable_reference_value(napi_env env,
  2. napi_sendable_ref ref,
  3. napi_value* result);

其他实用工具

展开

接口 功能说明
napi_get_version 获取Node运行时支持的最高 NAPI 版本。
node_api_get_module_file_name 用于获取加载项加载位置的绝对路径。
napi_strict_equals 当需要确保两个值不仅值相等且类型也相同时(例如处理特定类型的数据结构或算法时),可以使用napi_strict_equals来保证数据一致性。
Logo

作为“人工智能6S店”的官方数字引擎,为AI开发者与企业提供一个覆盖软硬件全栈、一站式门户。

更多推荐