纯血鸿蒙Native层支持说明

本文所有描述均参考鸿蒙官方文档:传送门

1.对C库的支持

C标准函数库在C语言程序设计中,提供符合标准的头文件,以及常用的库函数实现(如I/O输入输出和字符串控制)。

HarmonyOS采用musl作为C标准库,musl库是一个轻量,快速,简单,免费的开源libc库,详细介绍参考musl官方参考手册。

musl与glibc的差异点请参考musl与glibc功能对比。

标准C库组件介绍

libc、libm、libdl组合实现C11标准C库。

libc:包含线程相关接口,以及大部分标准接口。

libm:数学库函数接口,当前在HarmonyOS中是一个链接,实际都在libc中定义。

libdl:dlopen等动态链接器接口,当前在HarmonyOS中是一个链接,实际都在libc中定义。

musl版本号

1.2.0

从HarmonyOS4.0开始,版本升级到1.2.3

从HarmonyOS5.0开始,版本升级到1.2.5

支持的能力

提供兼容C99,C11,POSIX标准的头文件,以及库函数接口,但不是完全兼容;支持armv7a,arm64, x86_64三种架构的支持;

为了更好的适配HarmonyOS设备的高性能,低内存,高安全,轻量化,支持多种形态设备的基本特征;在musl开源库的基础上进行了优化,增强,对不适用嵌入式设备的接口进行了裁剪。

2.对C++库的支持

HarmonyOS使用llvm开源项目的C++标准库libc++作为C++运行时库。

libc++版本

从HarmonyOS 4.0开始,libc++升级到clang/llvm 15.0.4版本

从HarmonyOS 3.2开始,libc++升级到clang/llvm 12.0.1版本

从HarmonyOS 3.0开始,libc++使用clang/llvm 10.0.1版本

C++语言支持能力

C++11、C++14标准已完全支持,C++17和C++20标准正在完善。具体语言特性支持标准可以参考“libc++” C++ Standard Library — libc++ documentation网站对应的Release Notes。

如何在CMake中选择C++

在NDK的{ndk_root}/build/cmake/ohos.toolchain.cmake文件中,定义了OHOS_STL变量,可以通过设置"c++_shared"或者"c++_static"来控制应用工程中原生库链接C++运行库的方式。

  • c++_shared,原生库动态链接libc++_shared.so
  • c++_static,原生库静态链接libc++_static.a

3.对NAPI支持

已从Node-API组件标准库中导出的符号列表

从Node-API标准库导出的接口,其使用方法及行为基于Node.js,并进行了部分能力拓展。

符号类型

符号名

说明

起始支持API版本

FUNC

napi_module_register

napi native模块注册接口。

10

FUNC

napi_get_last_error_info

获取napi_extended_error_info结构体,其中包含最近一次出现的error信息。

10

FUNC

napi_throw

抛出一个js value。

10

FUNC

napi_throw_error

抛出一个带文本信息的js Error。

10

FUNC

napi_throw_type_error

抛出一个带文本信息的js TypeError。

10

FUNC

napi_throw_range_error

抛出一个带文本信息的js RangeError。

10

FUNC

napi_is_error

判断napi_value是否表示为一个error对象。

10

FUNC

napi_create_error

创建并获取一个带文本信息的js Error。

10

FUNC

napi_create_type_error

创建并获取一个带文本信息的js TypeError。

10

FUNC

napi_create_range_error

创建并获取一个带文本信息的js RangeError。

10

FUNC

napi_get_and_clear_last_exception

获取并清除最近一次出现的异常。

10

FUNC

napi_is_exception_pending

判断是否出现了异常。

10

FUNC

napi_fatal_error

引发致命错误以立即终止进程。

10

FUNC

napi_open_handle_scope

创建一个上下文环境使用。

10

FUNC

napi_close_handle_scope

关闭传入的上下文环境,关闭后,全部在其中声明的引用都将被关闭。

10

FUNC

napi_open_escapable_handle_scope

创建出一个可逃逸的handel scope,可将范围内声明的值返回到父作用域。

10

FUNC

napi_close_escapable_handle_scope

关闭传入的可逃逸的handel scope。

10

FUNC

napi_escape_handle

提升传入的js object的生命周期到其父作用域。

10

FUNC

napi_create_reference

为Object创建一个reference,以延长其生命周期。调用者需要自己管理reference生命周期。

10

FUNC

napi_delete_reference

删除传入的reference。

10

FUNC

napi_reference_ref

增加传入的reference的引用计数,并获取该计数。

10

FUNC

napi_reference_unref

减少传入的reference的引用计数,并获取该计数。

10

FUNC

napi_get_reference_value

获取与reference相关联的js Object。

10

FUNC

napi_create_array

创建并获取一个js Array。

10

FUNC

napi_create_array_with_length

创建并获取一个指定长度的js Array。

10

FUNC

napi_create_arraybuffer

创建并获取一个指定大小的js ArrayBuffer。

10

FUNC

napi_create_external

分配一个附加有外部数据的js value。

10

FUNC

napi_create_external_arraybuffer

分配一个附加有外部数据的js ArrayBuffer。

10

FUNC

napi_create_object

创建一个默认的js Object。

10

FUNC

napi_create_symbol

创建一个js Symbol。

10

FUNC

napi_create_typedarray

通过现有的ArrayBuffer创建一个js TypeArray。

10

FUNC

napi_create_dataview

通过现有的ArrayBuffer创建一个js DataView。

10

FUNC

napi_create_int32

通过一个C的int32_t数据创建js Number。

10

FUNC

napi_create_uint32

通过一个C的uint32_t数据创建js Number。

10

FUNC

napi_create_int64

通过一个C的int64_t数据创建js Number。

10

FUNC

napi_create_double

通过一个C的double数据创建js Number。

10

FUNC

napi_create_string_latin1

通过ISO-8859-1编码的C字符串数据创建js String。

10

FUNC

napi_create_string_utf8

通过UTF8编码的C字符串数据创建js String。

10

FUNC

napi_create_string_utf16

通过UTF16编码的C字符串数据创建js String。

10

FUNC

napi_get_array_length

获取array的length。

10

FUNC

napi_get_arraybuffer_info

获取ArrayBuffer的底层data buffer及其长度。

10

FUNC

napi_get_prototype

获取给定js Object的prototype。

10

FUNC

napi_get_typedarray_info

获取给定TypedArray的各种属性。

10

FUNC

napi_get_dataview_info

获取给定DataView的各种属性。

10

FUNC

napi_get_value_bool

获取给定js Boolean对应的C bool值。

10

FUNC

napi_get_value_double

获取给定js Number对应的C double值。

10

FUNC

napi_get_value_external

获取先前通过napi_create_external()传递的外部数据指针。

10

FUNC

napi_get_value_int32

获取给定js Number对应的C int32值。

10

FUNC

napi_get_value_int64

获取给定js Number对应的C int64值。

10

FUNC

napi_get_value_string_latin1

获取给定js vaule对应的ISO-8859-1编码的字符串。

10

FUNC

napi_get_value_string_utf8

获取给定js vaule对应的UTF8编码的字符串。

10

FUNC

napi_get_value_string_utf16

获取给定js vaule对应的UTF16编码的字符串。

10

FUNC

napi_get_value_uint32

获取给定js Number对应的C uint32值。

10

FUNC

napi_get_boolean

根据给定的C boolean值,获取js bool对象。

10

FUNC

napi_get_global

获取global对象。

10

FUNC

napi_get_null

获取null对象。

10

FUNC

napi_get_undefined

获取undefined对象。

10

FUNC

napi_coerce_to_bool

将给定的js value强转成js Boolean。

10

FUNC

napi_coerce_to_number

将给定的js value强转成js Number。

10

FUNC

napi_coerce_to_object

将给定的js value强转成js Object。

10

FUNC

napi_coerce_to_string

将给定的js value强转成js String。

10

FUNC

napi_typeof

获取给定js value的js type。

10

FUNC

napi_instanceof

判断给定object是否为给定constructor的实例。

10

FUNC

napi_is_array

判断给定js value是否为array。

10

FUNC

napi_is_arraybuffer

判断给定js value是否为ArrayBuffer。

10

FUNC

napi_is_typedarray

判断给定js value是否表示一个TypedArray。

10

FUNC

napi_is_dataview

判断给定js value是否表示一个DataView。

10

FUNC

napi_is_date

判断给定js value是否为js Date对象。

10

FUNC

napi_strict_equals

判断给定的两个js value是否严格相等。

10

FUNC

napi_get_property_names

以字符串数组的形式获取对象的可枚举属性的名称。

10

FUNC

napi_set_property

对给定Object设置属性。

10

FUNC

napi_get_property

获取给定Object的给定属性。

10

FUNC

napi_has_property

判断给定对象中是否存在给定属性。

10

FUNC

napi_delete_property

尝试从给定Object中删除给定key属性。

10

FUNC

napi_has_own_property

判断给定Object中是否有名为key的own property。

10

FUNC

napi_set_named_property

对给定Object设置一个给定名称的属性。

10

FUNC

napi_get_named_property

获取给定Object中指定名称的属性。

10

FUNC

napi_has_named_property

判断给定Object中是否有给定名称的属性。

10

FUNC

napi_set_element

在给定Object的指定索引处,设置元素。

10

FUNC

napi_get_element

获取给定Object指定索引处的元素。

10

FUNC

napi_has_element

若给定Object的指定索引处拥有属性,获取该元素。

10

FUNC

napi_delete_element

尝试删除给定Object的指定索引处的元素。

10

FUNC

napi_define_properties

批量的向给定Object中定义属性。

10

FUNC

napi_type_tag_object

将tag指针的值与Object关联。

10

FUNC

napi_check_object_type_tag

判断给定的tag指针是否被关联到了js Object上。

10

FUNC

napi_call_function

在Native方法中调用js function,即native call js。

10

FUNC

napi_create_function

创建native方法给js使用,以便于js call native。

10

FUNC

napi_get_cb_info

从给定的callback info中获取有关调用的详细信息,如参数和this指针。

10

FUNC

napi_get_new_target

获取构造函数调用的new.target。

10

FUNC

napi_new_instance

通过给定的构造函数,构建一个实例。

10

FUNC

napi_define_class

定义与C++类相对应的JavaScript类。

10

FUNC

napi_wrap

在js object上绑定一个native对象实例。

10

FUNC

napi_unwrap

从js object上获取先前绑定的native对象实例。

10

FUNC

napi_remove_wrap

从js object上获取先前绑定的native对象实例,并解除绑定。

10

FUNC

napi_create_async_work

创建一个异步工作对象。

10

FUNC

napi_delete_async_work

释放先前创建的异步工作对象。

10

FUNC

napi_queue_async_work

将异步工作对象加到队列,由底层去调度执行。

10

FUNC

napi_cancel_async_work

取消入队的异步任务。

10

FUNC

napi_async_init

创建一个异步资源上下文环境(不支持与async_hook相关能力)。

11

FUNC

napi_make_callback

在异步资源上下文环境中回调JS函数(不支持与async_hook相关能力)。

11

FUNC

napi_async_destroy

销毁先前创建的异步资源上下文环境(不支持与async_hook相关能力)。

11

FUNC

napi_open_callback_scope

创建一个回调作用域(不支持与async_hook相关能力)。

11

FUNC

napi_close_callback_scope

关闭先前创建的回调作用域(不支持与async_hook相关能力)。

11

FUNC

napi_get_node_version

获取node的版本信息。

10

FUNC

napi_get_version

获取Node运行时支持的最高 N-API 版本。

10

FUNC

napi_create_promise

创建一个延迟对象和js promise。

10

FUNC

napi_resolve_deferred

resolve与js promise对象关联的延迟函数。

10

FUNC

napi_reject_deferred

reject与js promise对象关联的延迟函数。

10

FUNC

napi_is_promise

判断给定js value是否为promise对象。

10

FUNC

napi_get_uv_event_loop

获取当前libuv loop实例。

10

FUNC

napi_create_threadsafe_function

创建线程安全函数。

10

FUNC

napi_get_threadsafe_function_context

获取线程安全函数中的context。

10

FUNC

napi_call_threadsafe_function

调用线程安全函数。

10

FUNC

napi_acquire_threadsafe_function

指示线程安全函数可以开始使用。

10

FUNC

napi_release_threadsafe_function

指示线程安全函数将停止使用。

10

FUNC

napi_ref_threadsafe_function

指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。

10

FUNC

napi_unref_threadsafe_function

指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。

10

FUNC

napi_create_date

通过一个C的double数据创建js Date。

10

FUNC

napi_get_date_value

获取给定js Date对应的C double值。

10

FUNC

napi_create_bigint_int64

通过一个C的int64数据创建js BigInt。

10

FUNC

napi_create_bigint_uint64

通过一个C的uint64数据创建js BigInt。

10

FUNC

napi_create_bigint_words

通过一个C的uint64数组创建单个js BigInt。

10

FUNC

napi_get_value_bigint_int64

获取给定js BigInt对应的C int64值。

10

FUNC

napi_get_value_bigint_uint64

获取给定js BigInt对应的C uint64值。

10

FUNC

napi_get_value_bigint_words

获取给定js BigInt对应的信息,包括符号位、64位小端序数组和数组中的元素个数。

10

FUNC

napi_create_buffer

创建并获取一个指定大小的js Buffer。

10

FUNC

napi_create_buffer_copy

创建并获取一个指定大小的js Buffer,并以给定数据进行初始化。

10

FUNC

napi_create_external_buffer

创建并获取一个指定大小的js Buffer,并以给定数据进行初始化,该接口可为Buffer附带额外数据。

10

FUNC

napi_get_buffer_info

获取js Buffer底层data及其长度。

10

FUNC

napi_is_buffer

判断给定js value是否为Buffer对象。

10

FUNC

napi_object_freeze

冻结给定的对象。

10

FUNC

napi_object_seal

密封给定的对象。

10

FUNC

napi_get_all_property_names

获取一个数组,其中包含此对象过滤后的属性名称。

10

FUNC

napi_detach_arraybuffer

分离给定ArrayBuffer的底层数据。

10

FUNC

napi_is_detached_arraybuffer

判断给定的ArrayBuffer是否已被分离过。

10

FUNC

napi_run_script

将给定对象作为js代码运行。当前接口实际为空实现,可使用系统拓展接口napi_run_script_path接口,提升安全性。

10

FUNC

napi_set_instance_data

绑定与当前运行的环境相关联的数据项。

11

FUNC

napi_get_instance_data

检索与当前运行的环境相关联的数据项。

11

FUNC

napi_add_env_cleanup_hook

注册环境清理钩子函数。

11

FUNC

napi_remove_env_cleanup_hook

取消环境清理钩子函数。

11

FUNC

napi_add_async_cleanup_hook

注册清理异步钩子函数。

11

FUNC

napi_remove_async_cleanup_hook

取消清理异步钩子函数。

11

FUNC

node_api_get_module_file_name

用于获取加载项加载位置的绝对路径。

11

FUNC

napi_add_finalizer

当js Object中的对象被垃圾回收时调用注册的napi_finalize回调。

11

FUNC

napi_fatal_exception

向js抛出 UncaughtException。

12

未从Node-API组件标准库中导出的符号列表

符号类型

符号名

说明

FUNC

napi_adjust_external_memory

调整js Object持有的外部内存。

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

符号类型

符号名

说明

起始支持API版本

FUNC

napi_queue_async_work_with_qos

将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。

10

FUNC

napi_run_script_path

运行abc文件。

10

FUNC

napi_load_module

将abc文件作为模块加载,返回模块的命名空间。

11

FUNC

napi_create_object_with_properties

使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为 string,且不可转为number。

11

FUNC

napi_create_object_with_named_properties

使用给定的napi_value和键名创建js Object。键名必须为 string,且不可转为number。

11

FUNC

napi_coerce_to_native_binding_object

强制将js Object和Native对象绑定。

11

FUNC

napi_create_ark_runtime

创建基础运行时环境。

12

FUNC

napi_destroy_ark_runtime

销毁基础运行时环境。

12

FUNC

napi_run_event_loop

触发底层的事件循环。

12

FUNC

napi_stop_event_loop

停止底层的事件循环。

12

FUNC

napi_load_module_with_info

将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。

12

FUNC

napi_serialize

将ArkTS对象转换为native数据。

12

FUNC

napi_deserialize

将native数据转为ArkTS对象。

12

FUNC

napi_delete_serialization_data

删除序列化数据。

12

FUNC

napi_call_threadsafe_function_with_priority

将指定优先级和入队方式的任务投递到ArkTS主线程。

12

FUNC

napi_is_sendable

判断给定JS value是否是Sendable的。

12

FUNC

napi_define_sendable_class

创建一个sendable类。

12

FUNC

napi_create_sendable_object_with_properties

使用给定的napi_property_descriptor创建一个sendable对象。

12

FUNC

napi_create_sendable_array

创建一个sendable数组。

12

FUNC

napi_create_sendable_array_with_length

创建一个指定长度的sendable数组。

12

FUNC

napi_create_sendable_arraybuffer

创建一个sendable ArrayBuffer。

12

FUNC

napi_create_sendable_typedarray

创建一个sendable TypedArray。

12

FUNC

napi_wrap_sendable

包裹一个native实例到ArkTS对象中。

12

FUNC

napi_wrap_sendable_with_size

包裹一个native实例到ArkTS对象中并指定大小。

12

FUNC

napi_unwrap_sendable

获取ArkTS对象包裹的native实例。

12

FUNC

napi_remove_wrap_sendable

移除并获取ArkTS对象包裹的native实例。

12

napi_qos_t

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

描述:

表示QoS的枚举值,QoS决定了线程调度的优先级

napi_event_mode

typedef enum {napi_event_mode_default = 0,  // 阻塞式的运行底层事件循环,直到循环中没有任何任务时退出事件循环。napi_event_mode_nowait = 1,   // 非阻塞式的运行底层事件循环,尝试去处理一个任务,处理完之后退出事件循环;如果事件循环中没有任务,立刻退出事件循环。
} napi_event_mode;

描述:

用于运行事件循环的事件模式。

napi_queue_async_work_with_qos

napi_status napi_queue_async_work_with_qos(napi_env env,napi_async_work work,napi_qos_t qos);

描述:

将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] work: 一个表示异步工作项的对象。这个对象通常是通过napi_create_async_work函数创建的。
  • [in] qos: 决定了线程调度的优先级。

返回:

如果API成功,则返回napi_ok。

napi_run_script_path

napi_status napi_run_script_path(napi_env env,const char* abcPath,napi_value* result);

描述:

运行指定abc文件。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] abcPath: 要运行的脚本的JavaScript路径。这是一个字符串,指定了要运行的脚本文件的位置。
  • [out] result: 一个指向napi_value类型的指针,用于存储运行脚本的结果。

返回:

如果API成功,则返回napi_ok。

napi_load_module

napi_status napi_load_module(napi_env env,const char* path,napi_value* result);

描述:

加载系统模块或开发者自定义的模块,返回模块的命名空间。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] path: 要加载的系统模块的名称或开发者自定义模块的路径。
  • [out] result: 一个指向napi_value类型的指针,用于存储加载模块的结果。

返回:

如果API成功,则返回napi_ok。

napi_create_object_with_properties

napi_status napi_create_object_with_properties(napi_env env,napi_value* result,size_t property_count,const napi_property_descriptor* properties);

描述:

属性描述符napi_property_descriptor用于描述一个属性,它包括属性的名称获取和设置方法、属性特性等信息。通过传入这些描述符,可以在创建对象时就定义属性。

使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为string,且不可转为number。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
  • [in] property_count: 要添加到对象中的属性的数量。
  • [in] properties: 一个指向napi_property_descriptor数组的指针,描述了要添加到对象中的属性的信息。

返回:

如果API成功,则返回napi_ok。

napi_create_object_with_named_properties

napi_status napi_create_object_with_named_properties(napi_env env,napi_value* result,size_t property_count,const char** keys,const napi_value* values);

描述:

使用给定的napi_value和键名创建js Object。键名必须为string,且不可转为number。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
  • [in] property_count: 要添加到对象中的属性的数量。
  • [in] keys: 一个指向const char*数组的指针,表示属性的名称。
  • [in] values: 一个指向napi_value数组的指针,表示属性的值,与属性名称一一对应。

返回:

如果API成功,则返回napi_ok。

napi_coerce_to_native_binding_object

napi_status napi_coerce_to_native_binding_object(napi_env env,napi_value js_object,napi_native_binding_detach_callback detach_cb,napi_native_binding_attach_callback attach_cb,void* native_object,void* hint);

描述:

用于给JS Object绑定回调和回调所需的参数,转成携带Native信息的JS Object。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] js_object: 要转换的JavaScript对象。
  • [in] detach_cb: 解绑回调,一般在序列化时调用,可在对象解绑时执行一些清理操作。
  • [in] attach_cb: 绑定回调,一般在序列化时调用。
  • [in] native_object: 需要传递给回调的参数,不能为空。
  • [in] hint: 一个指针,可以用于传递附加的信息给回调函数。

返回:

如果API成功,则返回napi_ok。

napi_create_ark_runtime

napi_status napi_create_ark_runtime(napi_env *env)

描述:

创建基础运行时环境。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_destroy_ark_runtime

napi_status napi_destroy_ark_runtime(napi_env *env)

描述:

销毁基础运行时环境。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_run_event_loop

napi_status napi_run_event_loop(napi_env env, napi_event_mode mode)

描述:

触发底层的事件循环。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] mode: 用于运行事件循环的事件模式。

返回:

如果API成功,则返回napi_ok。

napi_stop_event_loop

napi_status napi_stop_event_loop(napi_env env)

描述:

停止底层的事件循环。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_load_module_with_info

napi_status napi_load_module_with_info(napi_env env,const char* path,const char* module_info,napi_value* result)

描述:

将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] path: 要加载的模块的路径。
  • [in] module_info: 模块信息。这是一个包含模块信息字符串。模块信息可以用于指定模块的版本、作者、描述等详细信息。
  • [out] result: 指向napi_value的指针,用于接收模块的结果。

返回:

如果API成功,则返回napi_ok。

napi_serialize

napi_status napi_serialize(napi_env env,napi_value object,napi_value transfer_list,napi_value clone_list,void** result)

描述:

将ArkTS对象转换为native数据。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] object: 要序列化的JavaScript对象。
  • [in] transfer_list: 传输列表,包含需要在序列化过程中转移的JavaScript对象。
  • [in] clone_list: 克隆列表,包含需要在序列化过程中克隆的JavaScript对象。
  • [out] result: 用于接收序列化结果的指针。在调用完成后,指向实际结果的指针会存储在此位置。

返回:

如果API成功,则返回napi_ok。

napi_deserialize

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

描述:

将native数据转为ArkTS对象。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] buffer: 指向包含二进制数据的指针。这些二进制数据需要被反序列化为JavaScript对象。
  • [out] object: 用于接收反序列化后的JavaScript对象。

返回:

如果API成功,则返回napi_ok。

napi_delete_serialization_data

napi_status napi_delete_serialization_data(napi_env env, void* buffer)

描述:

删除序列化数据。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] buffer: 指向包含序列化数据的内存缓冲区的指针。这些数据在序列化完成后不再需要,并且可以通过调用此函数来释放相应的内存。

返回:

如果API成功,则返回napi_ok。

napi_call_threadsafe_function_with_priority

napi_status napi_call_threadsafe_function_with_priority(napi_threadsafe_function func,void *data,napi_task_priority priority,bool isTail)

描述:

将指定优先级和入队方式的任务投递到ArkTS主线程。

参数:

  • [in] func: 线程安全函数对象,在创建线程安全函数时返回。
  • [in] data: 传递给 JavaScript 回调函数的参数数据。
  • [in] priority: 指定调用 JavaScript 回调函数的任务优先级。
  • [in] isTail: 一个布尔值,指示调用是否应该排队等待在事件循环的尾部执行。如果为 true,则调用将在事件循环的尾部执行;如果为 false,则调用将立即执行,不会排队等待。

返回:

如果API成功,则返回napi_ok。

napi_is_sendable

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

描述:

判断给定JS value是否是Sendable的。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] value: 一个napi_value类型的参数,是需要判断的值。
  • [out] result: 一个bool类型的指针,用于存储判断结果。

返回:

如果API成功,则返回napi_ok。

napi_define_sendable_class

napi_status napi_define_sendable_class(napi_env env,const char* utf8name,size_t length,napi_callback constructor,void* data,size_t property_count,const napi_property_descriptor* properties,napi_value parent,napi_value* result)

描述:

创建一个sendable类。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] utf8name:一个const char*类型的参数,表示类的名称。
  • [in] length:一个size_t类型的参数,表示类名称的字节数。
  • [in] constructor:一个napi_callback类型的参数,表示类的构造函数。
  • [in] data:[可选]一个void*类型的参数,表示构造函数的附加数据。
  • [in] property_count:一个size_t类型的参数,表示类的属性数量。
  • [in] properties:[可选]一个const napi_property_descriptor*类型的参数,表示类的属性描述符数组。
  • [in] parent:[可选]一个napi_value类型的参数,表示父类。
  • [out] result:一个napi_value类型的指针,用于存储创建的对象。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_object_with_properties

napi_status napi_create_sendable_object_with_properties(napi_env env,size_t property_count,const napi_property_descriptor* properties,napi_value* result)

描述:

使用给定的napi_property_descriptor创建一个sendable对象。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] property_count:一个size_t类型的参数,表示属性数量。
  • [in] properties:一个const napi_property_descriptor*类型的参数,表示属性描述符数组。
  • [out] result:一个napi_value类型的指针,用于存储创建的对象。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_array

napi_status napi_create_sendable_array(napi_env env, napi_value* result)

描述:

创建一个sendable数组。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [out] result:一个napi_value类型的指针,用于存储创建的数组。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_array_with_length

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

描述:

创建一个指定长度的sendable数组。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] length:一个size_t类型的参数,表示数组的长度。
  • [out] result:一个napi_value类型的指针,用于存储创建的数组。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_arraybuffer

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

描述:

创建一个sendable ArrayBuffer。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] byte_length:要创建的ArrayBuffer的大小。
  • [in] data:指向底层字节缓冲区的指针。
  • [out] result:一个napi_value类型的指针,用于存储创建的ArrayBuffer。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_typedarray

napi_status napi_create_sendable_typedarray(napi_env env,napi_typedarray_type type,size_t length,napi_value arraybuffer,size_t byte_offset,napi_value* result);

描述:

创建一个sendable TypedArray。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] type:TypedArray 的类型。
  • [in] length:TypedArray 的长度。
  • [in] arraybuffer:一个 ArrayBuffer 实例。
  • [in] byte_offset:ArrayBuffer 的偏移量。
  • [out] result:一个napi_value类型的指针,用于存储创建的TypedArray。

返回:

如果API成功,则返回napi_ok。

napi_wrap_sendable

napi_status napi_wrap_sendable(napi_env env,napi_value js_object,void* native_object,napi_finalize finalize_cb,void* finalize_hint);

描述:

包裹一个native实例到ArkTS对象中。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] js_object:ArkTS对象。
  • [in] native_object:将被包裹在ArkTS对象中的native实例。
  • [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
  • [in] finalize_hint:[可选]上下文提示,会传递给回调函数。

返回:

如果API成功,则返回napi_ok。

napi_wrap_sendable_with_size

napi_status napi_wrap_sendable_with_size(napi_env env,napi_value js_object,void* native_object,napi_finalize finalize_cb,void* finalize_hint,size_t native_binding_size);

描述:

包装一个native实例到ArkTS对象中并指定大小。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] js_object:ArkTS对象。
  • [in] native_object:将被包裹在ArkTS对象中的native实例。
  • [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
  • [in] finalize_hint:[可选]上下文提示,会传递给回调函数。
  • [in] native_binding_size:[可选]绑定的native实例的大小。

返回:

如果API成功,则返回napi_ok。

napi_unwrap_sendable

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

描述:

获取ArkTS对象包装的native实例。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] js_object:ArkTS对象。
  • [out] result:包裹在ArkTS对象中的native实例。

返回:

如果API成功,则返回napi_ok。

napi_remove_wrap_sendable

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

描述:

移除并获取ArkTS对象包装的native实例。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] js_object:ArkTS对象。
  • [out] result:包裹在ArkTS对象中的native实例。

返回:

如果API成功,则返回napi_ok。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/466948.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Golang--协程和管道

1、概念 程序: 是为完成特定任务、用某种语言编写的一组指令的集合,是一段静态的代码。(程序是静态) 进程: 是程序的一次执行过程。正在运行的一个程序,进程作为资源分配的单位,在内存中会为每个进程分配不同的内存区域&#xff0…

动力商城-02 环境搭建

1.父工程必须满足&#xff1a;1.1删除src目录 1.2pom 2.依赖继承 //里面的依赖&#xff0c;后代无条件继承<dependencies></dependencies>//里面的依赖&#xff0c;后代想要继承&#xff0c;得自己声明需要使用&#xff0c;可以不写版本号&#xff0c;自动继承&l…

JavaWeb开发9

ResponseBody 类型&#xff1a;方法注解、类注解 位置&#xff1a;Controller方法上/类上 作用&#xff1a;将方法返回值直接响应&#xff0c;如果返回值类型是实体对象/集合&#xff0c;将会转换为JSON格式响应 说明&#xff1a;RestControllerControllerResponseBody; 统…

夜天之书 #103 开源嘉年华纪实

上周在北京参与了开源社主办的 2024 中国开源年会。其实相比于有点明显班味的“年会”&#xff0c;我的参会体验更像是经历了一场中国开源的年度嘉年华。这也是在会场和其他参会朋友交流时共同的体验&#xff1a;在开源社的 COSCon 活动上&#xff0c;能够最大限度地一次性见到…

06 Oracle性能优化秘籍:AWR、ASH、SQL trace与实时监控的实战指南

文章目录 Oracle性能优化秘籍&#xff1a;AWR、ASH、SQL trace与实时监控的实战指南一、AWR&#xff08;Automatic Workload Repository&#xff09;1.1 理论部分1.2 实践部分1.2.1 使用方式1.2.2 分析方式 二、ASH&#xff08;Active Session History&#xff09;2.1 理论部分…

JS实现,防抖节流 + 闭包

防抖&#xff08;Debounce&#xff09; 防抖是指短时间内大量触发同一事件&#xff0c;只会在最后一次事件完成后延迟执行一次函数。 防抖的典型应用场景是输入框的搜索建议功能&#xff0c;用户输入时不需要每次输入都去查询&#xff0c;而是在用户停止输入一段时间后才进行…

1.每日SQL----2024/11/7

题目&#xff1a; 计算用户次日留存率,即用户第二天继续登录的概率 表&#xff1a; iddevice_iddate121382024-05-03232142024-05-09332142024-06-15465432024-08-13523152024-08-13623152024-08-14723152024-08-15832142024-05-09932142024-08-151065432024-08-131123152024-…

WPF中如何简单的使用MvvmLight创建一个项目并进行 增删改查

目录 第一步&#xff1a;创建项目后下载如下两个NuGet程序包&#xff0c;然后删除删掉using Microsoft.Practices.ServiceLocation; 并且引入using CommonServiceLocator; 第二步&#xff1a;删除原来的XAML文件并创建如下的包结构然后创建一个在View文件夹中创建一个Main窗体 …

网页版五子棋——匹配模块(客户端开发)

前一篇文章&#xff1a;网页版五子棋——用户模块&#xff08;客户端开发&#xff09;-CSDN博客 目录 前言 一、前后端交互接口设计 二、游戏大厅页面 1.页面代码编写 2.前后端交互代码编写 3.测试获取用户信息功能 结尾 前言 前面文章介绍完了五子棋项目用户模块的代码…

elasticSearch 7.12.1 Docker 安装ik分词

一、下载 https://github.com/infinilabs/analysis-ik/releases/tag/v7.12.1 将文件解压&#xff0c;复制到docker挂载的目录 docker ps#重启docker docker restart f7ec58e91f1f 测试 GET _analyze?pretty {"analyzer": "ik_max_word","text&qu…

在JS中, 0 == [0] 吗

在不知道答案的情况下, 你觉得这段代码的输出是什么 我当时觉得是false, 结果我错了–^^– 那为什么输出是true呢 因为的隐式类型转换, 运算符会尝试将两个操作数转换为相同的类型&#xff0c;然后再进行比较。 在这个例子中&#xff0c;0 是一个数字&#xff0c;而 [0] 是…

【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】

【学习AI-相关路程-mnist手写数字分类-win-硬件&#xff1a;windows-自我学习AI-实验步骤-全连接神经网络&#xff08;BPnetwork&#xff09;-操作流程&#xff08;3&#xff09; 】 1、前言2、前置学习&#xff08;1&#xff09;window和Linux中python寻找目录的方式。&#x…

RabbitMQ客户端应用开发实战

这一章节我们将快速完成RabbitMQ客户端基础功能的开发实战。 一、回顾RabbitMQ基础概念 这个RabbitMQ的核心组件&#xff0c;是进行应用开发的基础。 二、RabbitMQ基础编程模型 RabbitMQ提供了很多种主流编程语言的客户端支持。这里我们只分析Java语言的客户端。 上一章节提…

一文了解Android SELinux

在Android系统中&#xff0c;SELinux&#xff08;Security-Enhanced Linux&#xff09;是一个增强的安全机制&#xff0c;用于对系统进行强制访问控制&#xff08;Mandatory Access Control&#xff0c;MAC&#xff09;。它限制了应用程序和进程的访问权限&#xff0c;提供了更…

python画图|hist()函数深层体验

【1】引言 前述学习已经掌握hist()函数的基本运用技巧&#xff0c;可通过下述链接直达&#xff1a; python画图|hist()函数画直方图初探-CSDN博客 python画图|hist()函数画直方图进阶-CSDN博客 我们已经理解hist()函数本质上画的是概率分布图&#xff0c;相关知识属于数理统…

火狐浏览器同源策略禁止解决方案

前言 火狐浏览器同源策略禁止解决方案_同源策略禁止读取远程资源怎么办-CSDN博客 在使用Firefox火狐浏览器进行Web开发时&#xff0c;有时会遇到因为同源策略&#xff08;Same-Origin Policy&#xff09;导致的跨域请求被拦截的问题。例如&#xff0c;控制台可能会显示如下错…

计算机网络——TCP篇

TCP篇 基本认知 TCP和UDP的区别? TCP 和 UDP 可以使用同一个端口吗&#xff1f; 可以的 传输层中 TCP 和 UDP在内核中是两个完全独立的软件模块。可以根据协议字段来选择不同的模块来处理。 TCP 连接建立 TCP 三次握手过程是怎样的&#xff1f; 一次握手:客户端发送带有 …

解决ImportError: DLL load failed while importing _message: 找不到指定的程序。

C:\software\Anoconda\envs\yolov5_train\python.exe C:\Project\13_yolov5-master\train.py C:\software\Anoconda\envs\yolov5_train\lib\site-packages\torchvision\io\image.py:13: UserWarning: Failed to load image Python extension: [WinError 127] 找不到指定的程序…

AOSP沙盒android 11

这里介绍一下aosp装系统 什么是aosp AOSP&#xff08;Android Open Source Project&#xff09;是Android操作系统的开源版本。 它由Google主导&#xff0c;提供了Android的源代码和相关工具&#xff0c;供开发者使用和修改。 AOSP包含了Android的核心组件和API&#xff0c;使…

git提交冲突的原因及解决方案

一、场景一 1.冲突原因 提交者的版本库 < 远程库 要保障提交者的版本库信息和远程仓库是一致的 2.解决方案 实现本地同步git pull,再提交代码&#xff08;最好每次git push之前都git pull一下&#xff0c;防止这种情况的出现&#xff09; 场景二 1.冲突原因 别人跟你…